From 1cf5a72ce08da273c7d395d98a7ab3bdb191f38a Mon Sep 17 00:00:00 2001 From: Nazariy Date: Wed, 3 Dec 2025 23:50:14 +0200 Subject: [PATCH] add solution --- package-lock.json | 9 +++++---- package.json | 2 +- src/createServer.js | 20 ++++++++++++++++++-- 3 files changed, 24 insertions(+), 7 deletions(-) diff --git a/package-lock.json b/package-lock.json index 729a5b6..70a5ad7 100644 --- a/package-lock.json +++ b/package-lock.json @@ -11,7 +11,7 @@ "license": "GPL-3.0", "devDependencies": { "@mate-academy/eslint-config": "latest", - "@mate-academy/scripts": "^1.8.6", + "@mate-academy/scripts": "^2.1.2", "axios": "^1.7.2", "eslint": "^8.57.0", "eslint-plugin-jest": "^28.6.0", @@ -1468,10 +1468,11 @@ } }, "node_modules/@mate-academy/scripts": { - "version": "1.8.6", - "resolved": "https://registry.npmjs.org/@mate-academy/scripts/-/scripts-1.8.6.tgz", - "integrity": "sha512-b4om/whj4G9emyi84ORE3FRZzCRwRIesr8tJHXa8EvJdOaAPDpzcJ8A0sFfMsWH9NUOVmOwkBtOXDu5eZZ00Ig==", + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/@mate-academy/scripts/-/scripts-2.1.2.tgz", + "integrity": "sha512-gUXFdqqOfYzF9R3RSx2pCa5GLdOkxB9bFbF+dpUpzucdgGAANqOGdqpmNnMj+e3xA9YHraUWq3xo9cwe5vD9pQ==", "dev": true, + "license": "MIT", "dependencies": { "@octokit/rest": "^17.11.2", "@types/get-port": "^4.2.0", diff --git a/package.json b/package.json index c4d3c53..318e87c 100644 --- a/package.json +++ b/package.json @@ -17,7 +17,7 @@ "license": "GPL-3.0", "devDependencies": { "@mate-academy/eslint-config": "latest", - "@mate-academy/scripts": "^1.8.6", + "@mate-academy/scripts": "^2.1.2", "axios": "^1.7.2", "eslint": "^8.57.0", "eslint-plugin-jest": "^28.6.0", diff --git a/src/createServer.js b/src/createServer.js index 1fc5f4e..2fa0aea 100644 --- a/src/createServer.js +++ b/src/createServer.js @@ -1,9 +1,25 @@ /* eslint-disable no-console */ 'use strict'; +const http = require('http'); +const url = require('url'); + +const getParts = (path) => path.split('/').filter((p) => p !== '/' && p !== ''); +const getQuery = (searchParams) => Object.fromEntries(searchParams.entries()); + function createServer() { - /* Write your code here */ - // Return instance of http.Server class + return http.createServer((req, res) => { + const normalizedUrl = new url.URL(req.url, 'http://localhost'); + + res.setHeader('Content-Type', 'application/json'); + + res.end( + JSON.stringify({ + parts: getParts(normalizedUrl.pathname), + query: getQuery(normalizedUrl.searchParams), + }), + ); + }); } module.exports = {