implementing udp server
This commit is contained in:
@@ -1,9 +1,10 @@
|
|||||||
{
|
{
|
||||||
"name": "netstar-categorizer",
|
"name": "netstar-categorizer",
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"main": "src/app.js",
|
"main": "src/server.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "node --watch src/app.js"
|
"dev:server": "node --watch src/server.js",
|
||||||
|
"dev:client": "node src/client.js"
|
||||||
},
|
},
|
||||||
"keywords": [],
|
"keywords": [],
|
||||||
"author": "",
|
"author": "",
|
||||||
|
|||||||
19
src/app.js
19
src/app.js
@@ -1,16 +1,19 @@
|
|||||||
const { GetCategoryUseCase } = require('./use-cases/get-category-use-case.js')
|
const { GetCategoryUseCase } = require('./use-cases/get-category-use-case.js')
|
||||||
const categoriesMapping = require('./etc/categories-mapping.json')
|
|
||||||
const { CategoryConverterUseCase } = require('./use-cases/category-converter-use-case.js')
|
const { CategoryConverterUseCase } = require('./use-cases/category-converter-use-case.js')
|
||||||
|
|
||||||
const getCategoryUseCase = new GetCategoryUseCase();
|
const categoriesMapping = require('./etc/categories-mapping.json')
|
||||||
|
|
||||||
(async () => {
|
const getCategory = new GetCategoryUseCase();
|
||||||
const categoryId = await getCategoryUseCase.execute()
|
const categoryConverter = new CategoryConverterUseCase({categoriesMapping});
|
||||||
console.log(categoryId)
|
|
||||||
})()
|
module.exports = async function app(domain){
|
||||||
|
const category = await getCategory.execute(domain)
|
||||||
|
|
||||||
|
const categoryConverted = await categoryConverter.execute(category)
|
||||||
|
|
||||||
|
return categoryConverted
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// const categoryConverter = new CategoryConverterUseCase({ categoriesMapping })
|
// const categoryConverter = new CategoryConverterUseCase({ categoriesMapping })
|
||||||
|
|
||||||
|
|
||||||
getCategoryUseCase.execute('utorrent.com')
|
|
||||||
29
src/client.js
Normal file
29
src/client.js
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
const dgram = require('dgram');
|
||||||
|
const client = dgram.createSocket('udp4');
|
||||||
|
|
||||||
|
const message = Buffer.from('facebook.com');
|
||||||
|
|
||||||
|
const serverHost = 'localhost';
|
||||||
|
const serverPort = 41234;
|
||||||
|
|
||||||
|
client.send(message, 0, message.length, serverPort, serverHost, (err) => {
|
||||||
|
if (err) {
|
||||||
|
console.error(err);
|
||||||
|
client.close();
|
||||||
|
} else {
|
||||||
|
console.log('Message sent to server');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle incoming messages from the server
|
||||||
|
client.on('message', (msg, rinfo) => {
|
||||||
|
console.log(`Client received: ${msg} from ${rinfo.address}:${rinfo.port}`);
|
||||||
|
// Close the client socket if you don't expect any more messages
|
||||||
|
client.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Optional: handle any errors
|
||||||
|
client.on('error', (err) => {
|
||||||
|
console.log(`Client error: ${err.stack}`);
|
||||||
|
client.close();
|
||||||
|
});
|
||||||
25
src/server.js
Normal file
25
src/server.js
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
const dgram = require('dgram');
|
||||||
|
const server = dgram.createSocket('udp4');
|
||||||
|
const app = require('./app')
|
||||||
|
|
||||||
|
server.on('error', (err) => {
|
||||||
|
console.log(`Server error:\n${err.stack}`);
|
||||||
|
server.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
server.on('message', async (msg, rinfo) => {
|
||||||
|
console.log(`Server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
|
||||||
|
|
||||||
|
const categories = await app(msg.toString())
|
||||||
|
|
||||||
|
server.send(categories, rinfo.port, rinfo.address, (err) => {
|
||||||
|
if (err) server.close();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
server.on('listening', () => {
|
||||||
|
const address = server.address();
|
||||||
|
console.log(`Server listening ${address.address}:${address.port}`);
|
||||||
|
});
|
||||||
|
|
||||||
|
server.bind(41234);
|
||||||
@@ -4,8 +4,10 @@ class CategoryConverterUseCase {
|
|||||||
this.categoriesMapping = categoriesMapping
|
this.categoriesMapping = categoriesMapping
|
||||||
}
|
}
|
||||||
|
|
||||||
execute() {
|
execute(category) {
|
||||||
|
const entry = this.categoriesMapping.find(item => item.id === category)
|
||||||
|
|
||||||
|
return entry ? entry.related[0].split(', ').map(str => str.trim()) : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user