{"id":428712,"date":"2024-08-09T03:00:11","date_gmt":"2024-08-09T03:00:11","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=428712"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=428712","title":{"rendered":"<span>\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043f\u0443\u0441\u0442\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e NestJS-mod<\/span>"},"content":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u043e\u0441\u043b\u0435 \u043c\u043d\u043e\u0433\u0438\u0445 \u043b\u0435\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 NestJS \u0438 Angular, \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u0442\u044c \u0433\u0440\u0443\u043f\u043f\u0443 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0438\u0437 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f <a href=\"https:\/\/github.com\/rucken\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/rucken<\/a> \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0442\u0435\u043a\u0443\u0449\u0438\u0439 \u0441\u0442\u0438\u043b\u044c \u043a\u043e\u0434\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u043e\u043d \u043d\u0435 \u0441\u0438\u043b\u044c\u043d\u043e \u043f\u043e\u043c\u0435\u043d\u044f\u043b\u0441\u044f, \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u0442\u0430\u043b\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u043e\u0434\u043d\u043e\u0442\u0438\u043f\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430.<\/p>\n<p>\u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e fullstack-\u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442\u0430 \u0434\u043b\u044f \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0438 \u0431\u044d\u043a\u044d\u043d\u0434 \u0431\u0435\u0437 \u0431\u0438\u0437\u043d\u0435\u0441 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u0430 \u0431\u0443\u0434\u0443 \u0432\u0435\u0441\u0442\u0438 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 &#171;NestJS-mod&#187; (<a href=\"https:\/\/github.com\/nestjs-mod\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/nestjs-mod<\/a>).<\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442\u0430, \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u0435 \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u0435 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u0441\u044f \u0432 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 &#171;Rucken&#187; (<a href=\"https:\/\/github.com\/rucken\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/rucken<\/a>).<\/p>\n<p>\u0412\u0441\u0435 \u0448\u0430\u0433\u0438 \u0431\u0443\u0434\u0443 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0432 \u0441\u0442\u0438\u043b\u0435 \u043a\u0430\u043a \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u043b \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 &#171;KaufmanBot&#187; (<a href=\"https:\/\/dev.to\/endykaufman\/series\/16805\" rel=\"noopener noreferrer nofollow\">https:\/\/dev.to\/endykaufman\/series\/16805<\/a>)<\/p>\n<h4>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0443\u0441\u0442\u043e\u0439 NestJS-mod \u043f\u0440\u043e\u0435\u043a\u0442 \u0438 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f \u043d\u0430\u0448\u0443 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u044e<\/h4>\n<p>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0443\u0441\u0442\u043e\u0439 \u043c\u043e\u043d\u043e\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439 \u0441 nx-workspace, \u0434\u0430\u043b\u0435\u0435 \u0432 \u043d\u0435\u043c \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0436\u0435 \u0431\u0443\u0434\u0443\u0442 \u0438\u043c\u0435\u0442\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u0438\u043c\u0435\u043d\u0430.<\/p>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\"># Create empty nx project npx --yes create-nx-workspace@19.5.3 --name=nestjs-mod-fullstack --preset=apps --interactive=false --ci=skip  # Go to created project cd nestjs-mod-fullstack <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ npx --yes create-nx-workspace@19.5.3 --name=nestjs-mod-fullstack --preset=apps --interactive=false --ci=skip NX   Let's create a new workspace [https:\/\/nx.dev\/getting-started\/intro]    NX   Creating your v19.5.3 workspace.  \u2714 Installing dependencies with npm \u2714 Successfully created the workspace: nestjs-mod-fullstack.   NX   Directory is already under version control. Skipping initialization of git.   \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014    NX   Nx CLI is not installed globally.  This means that you will have to use \"npx nx\" to execute commands in the workspace. Run \"npm i -g nx\" to be able to execute command directly.   \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014    NX   First time using Nx? Check out this interactive Nx tutorial.  https:\/\/nx.dev\/getting-started\/tutorials\/npm-workspaces-tutorial <\/code><\/pre>\n<h4>\u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0443\u0441\u0442\u043e\u0435 NestJS-mod &#8212; \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\"># Install all need main dev-dependencies npm install --save-dev @nestjs-mod\/schematics@latest  # Create NestJS-mod application .\/node_modules\/.bin\/nx g @nestjs-mod\/schematics:application --directory=apps\/server --name=server --projectNameAndRootFormat=as-provided --strict=true <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ npm install --save-dev @nestjs-mod\/schematics@latest npm WARN deprecated inflight@1.0.6: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful. npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported  added 199 packages, and audited 560 packages in 12s  64 packages are looking for funding   run `npm fund` for details  found 0 vulnerabilities  $ .\/node_modules\/.bin\/nx g @nestjs-mod\/schematics:application --directory=apps\/server --name=server --projectNameAndRootFormat=as-provided --strict=true   NX  Generating @nestjs-mod\/schematics:application  Fetching prettier... Fetching @nx\/webpack... UPDATE package.json CREATE rucken.json CREATE .nxignore UPDATE README.md CREATE tsconfig.base.json CREATE .prettierrc CREATE .prettierignore UPDATE .vscode\/extensions.json CREATE apps\/server\/src\/assets\/.gitkeep CREATE apps\/server\/src\/main.ts CREATE apps\/server\/tsconfig.app.json CREATE apps\/server\/tsconfig.json CREATE apps\/server\/webpack.config.js UPDATE nx.json CREATE apps\/server\/project.json CREATE .eslintrc.json CREATE .eslintignore CREATE apps\/server\/.eslintrc.json CREATE jest.preset.js CREATE jest.config.ts CREATE apps\/server\/jest.config.ts CREATE apps\/server\/tsconfig.spec.json CREATE apps\/server-e2e\/project.json CREATE apps\/server-e2e\/jest.config.ts CREATE apps\/server-e2e\/src\/server\/server.spec.ts CREATE apps\/server-e2e\/src\/support\/global-setup.ts CREATE apps\/server-e2e\/src\/support\/global-teardown.ts CREATE apps\/server-e2e\/src\/support\/test-setup.ts CREATE apps\/server-e2e\/tsconfig.json CREATE apps\/server-e2e\/tsconfig.spec.json CREATE apps\/server-e2e\/.eslintrc.json CREATE apps\/server\/src\/app\/app.controller.spec.ts CREATE apps\/server\/src\/app\/app.controller.ts CREATE apps\/server\/src\/app\/app.module.ts CREATE apps\/server\/src\/app\/app.service.spec.ts CREATE apps\/server\/src\/app\/app.service.ts CREATE .env CREATE apps\/server\/package.json npm WARN deprecated @humanwhocodes\/config-array@0.11.14: Use @eslint\/config-array instead npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated @ngneat\/transloco-utils@3.0.4: NOTICE: Transloco has moved to a new scope, this package will no longer receive updates. please use @jsverse\/transloco-utils instead. npm WARN deprecated @humanwhocodes\/object-schema@2.0.3: Use @eslint\/object-schema instead npm WARN deprecated glob@7.1.7: Glob versions prior to v9 are no longer supported npm WARN deprecated @ngneat\/transloco-scoped-libs@3.0.4: NOTICE: Transloco has moved to a new scope, this package will no longer receive updates. please use @jsverse\/transloco-scoped-libs instead. npm WARN deprecated q@1.5.1: You or someone you depend on is using Q, the JavaScript Promise library that gave JavaScript developers strong feelings about promises. They can almost certainly migrate to the native JavaScript promise now. Thank you literally everyone for joining me in this bet against the odds. Be excellent to each other. npm WARN deprecated npm WARN deprecated (For a CapTP with native promises, see @endo\/eventual-send and @endo\/captp) npm WARN deprecated @ngneat\/transloco-keys-manager@3.4.2: NOTICE: Transloco has moved to a new scope, this package will no longer receive updates. please use @jsverse\/transloco-keys-manager instead.  added 1152 packages, removed 9 packages, changed 14 packages, and audited 1913 packages in 25s  241 packages are looking for funding   run `npm fund` for details  11 vulnerabilities (1 moderate, 10 high) <\/code><\/pre>\n<h4>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 \u0438 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043a\u043e\u0434 \u0438 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\"># Build all applications and library npm run build  # Generate markdown report npm run docs:infrastructure <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$  npm run build  &gt; @nestjs-mod-fullstack\/source@0.0.0 build &gt; npm run generate &amp;&amp; npm run tsc:lint &amp;&amp; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=build --skip-nx-cache=true   &gt; @nestjs-mod-fullstack\/source@0.0.0 generate &gt; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=generate --skip-nx-cache=true &amp;&amp; npm run make-ts-list &amp;&amp; npm run lint:fix   NX   Successfully ran target generate for 0 projects (23ms)   &gt; @nestjs-mod-fullstack\/source@0.0.0 make-ts-list &gt; .\/node_modules\/.bin\/rucken make-ts-list   &gt; @nestjs-mod-fullstack\/source@0.0.0 lint:fix &gt; npm run tsc:lint &amp;&amp; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=lint --fix   &gt; @nestjs-mod-fullstack\/source@0.0.0 tsc:lint &gt; .\/node_modules\/.bin\/tsc --noEmit -p tsconfig.base.json      \u2714  nx run server-e2e:lint (1s)    \u2714  nx run server:lint (1s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target lint for 2 projects (1s)        With additional flags:         --fix=true   &gt; @nestjs-mod-fullstack\/source@0.0.0 tsc:lint &gt; .\/node_modules\/.bin\/tsc --noEmit -p tsconfig.base.json      \u2714  nx run server:build:production (3s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target build for project server (3s)  $ npm run docs:infrastructure  &gt; @nestjs-mod-fullstack\/source@0.0.0 docs:infrastructure &gt; export NESTJS_MODE=infrastructure &amp;&amp; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=start --parallel=1    NX   Running target start for project server:  - server  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014  &gt; nx run server:start  &gt; node dist\/apps\/server\/main.js  [00:14:38.808] INFO (390376): Starting Nest application...     context: \"NestFactory\" [00:14:38.808] INFO (390376): DefaultNestApp dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): ProjectUtilsSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationInitializerSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationInitializerShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): NestjsPinoLoggerModuleSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): NestjsPinoLoggerModuleShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): TerminusHealthCheckModuleSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationListenerSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationListenerShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): AppModuleSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): AppModuleShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): InfrastructureMarkdownReportGeneratorSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): Pm2Settings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): Pm2Shared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): ProjectUtils dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): InfrastructureMarkdownReportGeneratorSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): ProjectUtils dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): InfrastructureMarkdownReportStorage dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): InfrastructureMarkdownReportStorageSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): DefaultNestApplicationListenerSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): DefaultNestApplicationListenerShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): InfrastructureMarkdownReportStorageShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): AppModule dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): ProjectUtils dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): DefaultNestApplicationInitializer dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): DefaultNestApplicationListener dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): InfrastructureMarkdownReportGenerator dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): DefaultNestApplicationListener dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): NestjsPinoLoggerModule dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): TerminusModule dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): TerminusModule dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): ProjectUtilsShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): InfrastructureMarkdownReportGeneratorShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): Pm2 dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): InfrastructureMarkdownReportGeneratorShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): InfrastructureMarkdownReportGenerator dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): LoggerModule dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): TerminusHealthCheckModuleShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.809] INFO (390376): TerminusHealthCheckModule dependencies initialized     context: \"InstanceLoader\" [00:14:38.815] INFO (390376): TerminusHealthCheckController {\/health}:     context: \"RoutesResolver\" [00:14:38.817] INFO (390376): Mapped {\/health, GET} route     context: \"RouterExplorer\" [00:14:38.817] INFO (390376): AppController {\/}:     context: \"RoutesResolver\" [00:14:38.817] INFO (390376): Mapped {\/, GET} route     context: \"RouterExplorer\" [00:14:38.823] DEBUG (390376):     0: \"SERVER_PORT: Description='The port on which to run the server.', Default='3000', Original Name='port'\"     1: \"SERVER_HOSTNAME: Description='Hostname on which to listen for incoming packets.', Original Name='hostname'\"     context: \"All application environments\" [00:14:38.828] INFO (390376): Nest application successfully started     context: \"NestApplication\"  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target start for project server <\/code><\/pre>\n<h4>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u043f\u0440\u043e\u0435\u043a\u0442 \u0432 watch \u0440\u0435\u0436\u0438\u043c\u0435 \u0447\u0435\u0440\u0435\u0437 pm2<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\">npm run pm2:start <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ npm run pm2:start  &gt; @nestjs-mod-fullstack\/source@0.0.0 pm2:start &gt; .\/node_modules\/.bin\/pm2 start .\/ecosystem.config.json   &gt;&gt;&gt;&gt; In-memory PM2 is out-of-date, do: &gt;&gt;&gt;&gt; $ pm2 update In memory PM2 version: 3.1.3 Local PM2 version: 5.4.2  [PM2][WARN] Applications server not running, starting... [PM2] App [server] launched (1 instances) \u250c\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510 \u2502 id \u2502 name      \u2502 namespace   \u2502 version \u2502 mode    \u2502 pid      \u2502 uptime \u2502 \u21ba    \u2502 status    \u2502 cpu      \u2502 mem      \u2502 user     \u2502 watching \u2502 \u251c\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524 \u2502 0  \u2502 server    \u2502 default     \u2502 N\/A     \u2502 fork    \u2502 390932   \u2502 0s     \u2502 0    \u2502 online    \u2502 0%       \u2502 45.3mb   \u2502 endy     \u2502 disabled \u2502 \u2514\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518 <\/code><\/pre>\n<h4>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c \u044e\u043d\u0438\u0442-\u0442\u0435\u0441\u0442\u044b<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\">npm run test <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ npm run test  &gt; @nestjs-mod-fullstack\/source@0.0.0 test &gt; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=test --skip-nx-cache=true --passWithNoTests --output-style=stream-without-prefixes    &gt; nx run server:test --passWithNoTests   NX   Running target test for project server        With additional flags:         --passWithNoTests=true     \u2192  Executing 1\/1 remaining tasks...     \u2714  nx run server:test (2s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target test for project server (2s)        With additional flags:         --passWithNoTests=true <\/code><\/pre>\n<h4>\u0417\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c e2e-\u0442\u0435\u0441\u0442\u044b<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\">.\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=e2e --skip-nx-cache=true --passWithNoTests --output-style=stream-without-prefixes <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=e2e --skip-nx-cache=true --passWithNoTests --output-style=stream-without-prefixes   &gt; nx run server:build:production   NX   Running target e2e for project server-e2e and 1 task it depends on     \u2714  nx run server:build:production (3s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014     \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Running target e2e for project server-e2e and 1 task it depends on        With additional flags:         --passWithNoTests=true     \u2714  nx run server-e2e:e2e (2s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target e2e for project server-e2e and 1 task it depends on (4s)        With additional flags:         --passWithNoTests=true <\/code><\/pre>\n<h4>\u041e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c pm2 \u043f\u0440\u043e\u0435\u043a\u0442<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\">npm run pm2:stop <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$  npm run pm2:stop  &gt; @nestjs-mod-fullstack\/source@0.0.0 pm2:stop &gt; .\/node_modules\/.bin\/pm2 delete all   &gt;&gt;&gt;&gt; In-memory PM2 is out-of-date, do: &gt;&gt;&gt;&gt; $ pm2 update In memory PM2 version: 3.1.3 Local PM2 version: 5.4.2  [PM2] Applying action deleteProcessId on app [all](ids: [ 0 ]) [PM2] [server](0) \u2713 \u250c\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510 \u2502 id \u2502 name      \u2502 namespace   \u2502 version \u2502 mode    \u2502 pid      \u2502 uptime \u2502 \u21ba    \u2502 status    \u2502 cpu      \u2502 mem      \u2502 user     \u2502 watching \u2502 \u2514\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518 <\/code><\/pre>\n<p>\u0412 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c \u043f\u043e\u0441\u0442\u0435 \u044f \u0434\u043e\u0431\u0430\u0432\u043b\u044e \u043f\u0443\u0441\u0442\u043e\u0435 \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043d\u0430 Angular \u0438 \u0438\u0437 \u043d\u0435\u0433\u043e \u0432\u044b\u0437\u043e\u0432\u0443 \u043c\u0435\u0442\u043e\u0434\u044b \u0431\u044d\u043a\u0435\u043d\u0434 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f&#8230;<\/p>\n<h4>\u0421\u0441\u044b\u043b\u043a\u0438<\/h4>\n<p><a href=\"https:\/\/nestjs.com\" rel=\"noopener noreferrer nofollow\">https:\/\/nestjs.com<\/a> &#8212; \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0430\u0439\u0442 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430<br \/> <a href=\"https:\/\/nestjs-mod.com\" rel=\"noopener noreferrer nofollow\">https:\/\/nestjs-mod.com<\/a> &#8212; \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0430\u0439\u0442 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0445 \u0443\u0442\u0438\u043b\u0438\u0442<br \/> <a href=\"https:\/\/github.com\/nestjs-mod\/nestjs-mod-fullstack\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/nestjs-mod\/nestjs-mod-fullstack<\/a> &#8212; \u043f\u0440\u043e\u0435\u043a\u0442 \u0438\u0437 \u043f\u043e\u0441\u0442\u0430<\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><!----><!----><\/div>\n<p><!----><!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/834888\/\"> https:\/\/habr.com\/ru\/articles\/834888\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u043e\u0441\u043b\u0435 \u043c\u043d\u043e\u0433\u0438\u0445 \u043b\u0435\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 NestJS \u0438 Angular, \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u0442\u044c \u0433\u0440\u0443\u043f\u043f\u0443 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0438\u0437 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f <a href=\"https:\/\/github.com\/rucken\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/rucken<\/a> \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0442\u0435\u043a\u0443\u0449\u0438\u0439 \u0441\u0442\u0438\u043b\u044c \u043a\u043e\u0434\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u043e\u043d \u043d\u0435 \u0441\u0438\u043b\u044c\u043d\u043e \u043f\u043e\u043c\u0435\u043d\u044f\u043b\u0441\u044f, \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u0442\u0430\u043b\u043e \u043c\u0435\u043d\u044c\u0448\u0435 \u043e\u0434\u043d\u043e\u0442\u0438\u043f\u043d\u043e\u0433\u043e \u043a\u043e\u0434\u0430.<\/p>\n<p>\u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e fullstack-\u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442\u0430 \u0434\u043b\u044f \u0444\u0440\u043e\u043d\u0442\u0435\u043d\u0434 \u0438 \u0431\u044d\u043a\u044d\u043d\u0434 \u0431\u0435\u0437 \u0431\u0438\u0437\u043d\u0435\u0441 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u0430 \u0431\u0443\u0434\u0443 \u0432\u0435\u0441\u0442\u0438 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 &#171;NestJS-mod&#187; (<a href=\"https:\/\/github.com\/nestjs-mod\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/nestjs-mod<\/a>).<\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442\u0430, \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u0435 \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u0435 \u043f\u0440\u043e\u0434\u043e\u043b\u0436\u0438\u0442\u0441\u044f \u0432 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u0438 &#171;Rucken&#187; (<a href=\"https:\/\/github.com\/rucken\" rel=\"noopener noreferrer nofollow\">https:\/\/github.com\/rucken<\/a>).<\/p>\n<p>\u0412\u0441\u0435 \u0448\u0430\u0433\u0438 \u0431\u0443\u0434\u0443 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0432 \u0441\u0442\u0438\u043b\u0435 \u043a\u0430\u043a \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u043b \u0434\u043b\u044f \u043f\u0440\u043e\u0435\u043a\u0442\u0430 &#171;KaufmanBot&#187; (<a href=\"https:\/\/dev.to\/endykaufman\/series\/16805\" rel=\"noopener noreferrer nofollow\">https:\/\/dev.to\/endykaufman\/series\/16805<\/a>)<\/p>\n<h4>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0443\u0441\u0442\u043e\u0439 NestJS-mod \u043f\u0440\u043e\u0435\u043a\u0442 \u0438 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044f \u043d\u0430\u0448\u0443 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u044e<\/h4>\n<p>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0443\u0441\u0442\u043e\u0439 \u043c\u043e\u043d\u043e\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0439 \u0441 nx-workspace, \u0434\u0430\u043b\u0435\u0435 \u0432 \u043d\u0435\u043c \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0436\u0435 \u0431\u0443\u0434\u0443\u0442 \u0438\u043c\u0435\u0442\u044c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u0438\u043c\u0435\u043d\u0430.<\/p>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\"># Create empty nx project npx --yes create-nx-workspace@19.5.3 --name=nestjs-mod-fullstack --preset=apps --interactive=false --ci=skip  # Go to created project cd nestjs-mod-fullstack <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ npx --yes create-nx-workspace@19.5.3 --name=nestjs-mod-fullstack --preset=apps --interactive=false --ci=skip NX   Let's create a new workspace [https:\/\/nx.dev\/getting-started\/intro]    NX   Creating your v19.5.3 workspace.  \u2714 Installing dependencies with npm \u2714 Successfully created the workspace: nestjs-mod-fullstack.   NX   Directory is already under version control. Skipping initialization of git.   \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014    NX   Nx CLI is not installed globally.  This means that you will have to use \"npx nx\" to execute commands in the workspace. Run \"npm i -g nx\" to be able to execute command directly.   \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014    NX   First time using Nx? Check out this interactive Nx tutorial.  https:\/\/nx.dev\/getting-started\/tutorials\/npm-workspaces-tutorial <\/code><\/pre>\n<h4>\u0423\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0438 \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u043f\u0443\u0441\u0442\u043e\u0435 NestJS-mod &#8212; \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\"># Install all need main dev-dependencies npm install --save-dev @nestjs-mod\/schematics@latest  # Create NestJS-mod application .\/node_modules\/.bin\/nx g @nestjs-mod\/schematics:application --directory=apps\/server --name=server --projectNameAndRootFormat=as-provided --strict=true <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$ npm install --save-dev @nestjs-mod\/schematics@latest npm WARN deprecated inflight@1.0.6: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful. npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported  added 199 packages, and audited 560 packages in 12s  64 packages are looking for funding   run `npm fund` for details  found 0 vulnerabilities  $ .\/node_modules\/.bin\/nx g @nestjs-mod\/schematics:application --directory=apps\/server --name=server --projectNameAndRootFormat=as-provided --strict=true   NX  Generating @nestjs-mod\/schematics:application  Fetching prettier... Fetching @nx\/webpack... UPDATE package.json CREATE rucken.json CREATE .nxignore UPDATE README.md CREATE tsconfig.base.json CREATE .prettierrc CREATE .prettierignore UPDATE .vscode\/extensions.json CREATE apps\/server\/src\/assets\/.gitkeep CREATE apps\/server\/src\/main.ts CREATE apps\/server\/tsconfig.app.json CREATE apps\/server\/tsconfig.json CREATE apps\/server\/webpack.config.js UPDATE nx.json CREATE apps\/server\/project.json CREATE .eslintrc.json CREATE .eslintignore CREATE apps\/server\/.eslintrc.json CREATE jest.preset.js CREATE jest.config.ts CREATE apps\/server\/jest.config.ts CREATE apps\/server\/tsconfig.spec.json CREATE apps\/server-e2e\/project.json CREATE apps\/server-e2e\/jest.config.ts CREATE apps\/server-e2e\/src\/server\/server.spec.ts CREATE apps\/server-e2e\/src\/support\/global-setup.ts CREATE apps\/server-e2e\/src\/support\/global-teardown.ts CREATE apps\/server-e2e\/src\/support\/test-setup.ts CREATE apps\/server-e2e\/tsconfig.json CREATE apps\/server-e2e\/tsconfig.spec.json CREATE apps\/server-e2e\/.eslintrc.json CREATE apps\/server\/src\/app\/app.controller.spec.ts CREATE apps\/server\/src\/app\/app.controller.ts CREATE apps\/server\/src\/app\/app.module.ts CREATE apps\/server\/src\/app\/app.service.spec.ts CREATE apps\/server\/src\/app\/app.service.ts CREATE .env CREATE apps\/server\/package.json npm WARN deprecated @humanwhocodes\/config-array@0.11.14: Use @eslint\/config-array instead npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated @ngneat\/transloco-utils@3.0.4: NOTICE: Transloco has moved to a new scope, this package will no longer receive updates. please use @jsverse\/transloco-utils instead. npm WARN deprecated @humanwhocodes\/object-schema@2.0.3: Use @eslint\/object-schema instead npm WARN deprecated glob@7.1.7: Glob versions prior to v9 are no longer supported npm WARN deprecated @ngneat\/transloco-scoped-libs@3.0.4: NOTICE: Transloco has moved to a new scope, this package will no longer receive updates. please use @jsverse\/transloco-scoped-libs instead. npm WARN deprecated q@1.5.1: You or someone you depend on is using Q, the JavaScript Promise library that gave JavaScript developers strong feelings about promises. They can almost certainly migrate to the native JavaScript promise now. Thank you literally everyone for joining me in this bet against the odds. Be excellent to each other. npm WARN deprecated npm WARN deprecated (For a CapTP with native promises, see @endo\/eventual-send and @endo\/captp) npm WARN deprecated @ngneat\/transloco-keys-manager@3.4.2: NOTICE: Transloco has moved to a new scope, this package will no longer receive updates. please use @jsverse\/transloco-keys-manager instead.  added 1152 packages, removed 9 packages, changed 14 packages, and audited 1913 packages in 25s  241 packages are looking for funding   run `npm fund` for details  11 vulnerabilities (1 moderate, 10 high) <\/code><\/pre>\n<h4>\u0421\u043e\u0437\u0434\u0430\u0435\u043c \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 \u0438 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0441\u043e\u0437\u0434\u0430\u0435\u043c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439 \u043a\u043e\u0434 \u0438 \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043f\u0440\u043e\u0435\u043a\u0442\u0430<\/h4>\n<p><em>\u041a\u043e\u043c\u0430\u043d\u0434\u044b<\/em><\/p>\n<pre><code class=\"bash\"># Build all applications and library npm run build  # Generate markdown report npm run docs:infrastructure <\/code><\/pre>\n<p><em>\u0412\u044b\u0432\u043e\u0434 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/em><\/p>\n<pre><code class=\"bash\">$  npm run build  &gt; @nestjs-mod-fullstack\/source@0.0.0 build &gt; npm run generate &amp;&amp; npm run tsc:lint &amp;&amp; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=build --skip-nx-cache=true   &gt; @nestjs-mod-fullstack\/source@0.0.0 generate &gt; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=generate --skip-nx-cache=true &amp;&amp; npm run make-ts-list &amp;&amp; npm run lint:fix   NX   Successfully ran target generate for 0 projects (23ms)   &gt; @nestjs-mod-fullstack\/source@0.0.0 make-ts-list &gt; .\/node_modules\/.bin\/rucken make-ts-list   &gt; @nestjs-mod-fullstack\/source@0.0.0 lint:fix &gt; npm run tsc:lint &amp;&amp; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=lint --fix   &gt; @nestjs-mod-fullstack\/source@0.0.0 tsc:lint &gt; .\/node_modules\/.bin\/tsc --noEmit -p tsconfig.base.json      \u2714  nx run server-e2e:lint (1s)    \u2714  nx run server:lint (1s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target lint for 2 projects (1s)        With additional flags:         --fix=true   &gt; @nestjs-mod-fullstack\/source@0.0.0 tsc:lint &gt; .\/node_modules\/.bin\/tsc --noEmit -p tsconfig.base.json      \u2714  nx run server:build:production (3s)  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014   NX   Successfully ran target build for project server (3s)  $ npm run docs:infrastructure  &gt; @nestjs-mod-fullstack\/source@0.0.0 docs:infrastructure &gt; export NESTJS_MODE=infrastructure &amp;&amp; .\/node_modules\/.bin\/nx run-many --exclude=@nestjs-mod-fullstack\/source --all -t=start --parallel=1    NX   Running target start for project server:  - server  \u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014\u2014  &gt; nx run server:start  &gt; node dist\/apps\/server\/main.js  [00:14:38.808] INFO (390376): Starting Nest application...     context: \"NestFactory\" [00:14:38.808] INFO (390376): DefaultNestApp dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): ProjectUtilsSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationInitializerSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationInitializerShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): NestjsPinoLoggerModuleSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): NestjsPinoLoggerModuleShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): TerminusHealthCheckModuleSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationListenerSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): DefaultNestApplicationListenerShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): AppModuleSettings dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): AppModuleShared dependencies initialized     context: \"InstanceLoader\" [00:14:38.808] INFO (390376): InfrastructureMarkdownReportGeneratorSettings dependencies<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-428712","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/428712","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=428712"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/428712\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=428712"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=428712"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=428712"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}