-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2 from RnizereB/module1-task2
Приложение для терминала
- Loading branch information
Showing
17 changed files
with
363 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
Beautiful & luxurious studio at great location. A quiet cozy and picturesque that hides behind a a river by the unique lightness of Amsterdam. 2024-09-10T10:30:30.000Z Paris paris-preview.jpg paris-photo1.jpg,paris-photo2.jpg true true 4 apartment 2 3 2655 Breakfast;Washer;Fridge Jonh [email protected] user-jonh.jpg 123qwe Pro | ||
Waterfront with extraordinary view. I am happy to welcome you to my apartment in the city center! Three words: location, cosy and chic! 2024-09-11T11:30:45.000Z Cologne cologne-preview.jpg cologne-photo1.jpg,cologne-photo2.jpg false false 3 house 3 4 3540 Baby seat;Washer;Towels;Fridge Royce [email protected] user-royce.jpg poi331 Pro |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -30,5 +30,8 @@ | |
"engines": { | ||
"node": "^20.0.0", | ||
"npm": ">=10" | ||
}, | ||
"dependencies": { | ||
"chalk": "5.3.0" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
import { CommandParser } from './command-parser.js'; | ||
import { Command } from './commands/command.interface.js'; | ||
|
||
type CommandCollection = Record<string, Command> | ||
|
||
export class CLIApplication { | ||
|
||
constructor( | ||
private readonly defaultCommand: string = '--help' | ||
) {} | ||
|
||
private commands: CommandCollection = {}; | ||
|
||
public registerCommands(commandList: Command[]): void { | ||
commandList.forEach((command) => { | ||
|
||
if (Object.hasOwn(this.commands, command.getName())) { | ||
throw new Error (`Command ${command.getName()} is already registered`); | ||
} | ||
|
||
this.commands[command.getName()] = command; | ||
}); | ||
} | ||
|
||
public getDefaultCommand(): Command | never { | ||
if (! this.commands[this.defaultCommand]) { | ||
throw new Error(`The default command (${this.defaultCommand}) is not registered.`); | ||
} | ||
|
||
return this.commands[this.defaultCommand]; | ||
} | ||
|
||
public getCommand(commandName: string): Command { | ||
return this.commands[commandName] ?? this.getDefaultCommand(); | ||
} | ||
|
||
public processCommand(argv: string[]): void { | ||
const parsedCommand = CommandParser.parse(argv); | ||
const [commandName] = Object.keys(parsedCommand); | ||
const command = this.getCommand(commandName); | ||
const commandArguments = parsedCommand[commandName] ?? []; | ||
command.execute(...commandArguments); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
type ParsedCommand = Record<string, string[]> | ||
|
||
export class CommandParser { | ||
static parse(cliArguments: string[]): ParsedCommand { | ||
const parsedCommand: ParsedCommand = {}; | ||
let currentCommand = ''; | ||
|
||
for (const argument of cliArguments) { | ||
if (argument.startsWith('--')) { | ||
parsedCommand[argument] = []; | ||
currentCommand = argument; | ||
} else if (currentCommand && argument) { | ||
parsedCommand[currentCommand].push(argument); | ||
} | ||
} | ||
|
||
return parsedCommand; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
export interface Command { | ||
getName(): string; | ||
execute(... parameters: string[]): void; | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import { Command } from './command.interface.js'; | ||
|
||
export class HelpCommand implements Command { | ||
|
||
public getName(): string { | ||
return '--help'; | ||
} | ||
|
||
public async execute(..._parameters: string[]): Promise<void> { | ||
console.info(` | ||
Программа для подготовки данных для REST API сервера. | ||
Пример: | ||
cli.js --<command> [--arguments] | ||
Команды: | ||
--version: # выводит номер версии | ||
--help: # печатает этот текст | ||
--import <path>: # импортирует данные из TSV | ||
--generate <n> <path> <url> # генерирует произвольное количество тестовых данных | ||
`); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
import { TSVFileReader } from '../../shared/libs/file-reader/tsv-file-reader.js'; | ||
import { Command } from './command.interface.js'; | ||
|
||
export class ImportCommand implements Command { | ||
public getName(): string { | ||
return '--import'; | ||
} | ||
|
||
public execute(...parameters: string[]): void { | ||
const [filename] = parameters; | ||
const fileReader = new TSVFileReader(filename.trim()); | ||
|
||
try { | ||
fileReader.read(); | ||
console.log(fileReader.toArray()); | ||
} catch (err) { | ||
if (!(err instanceof Error)) { | ||
throw err; | ||
} | ||
|
||
console.error(`Can't import data from file: ${filename}`); | ||
console.error(`Details: ${err.message}`); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
import { Command } from './command.interface.js'; | ||
import { readFileSync } from 'node:fs'; | ||
import { resolve } from 'node:path'; | ||
|
||
type PackageJSONConfig = { | ||
version: string; | ||
} | ||
|
||
const isPackageJSONConfig = (value: unknown): value is PackageJSONConfig => ( | ||
typeof value === 'object' && | ||
value !== null && | ||
!Array.isArray(value) && | ||
Object.hasOwn(value, 'version') | ||
); | ||
|
||
export class VersionCommand implements Command { | ||
|
||
constructor( | ||
private readonly filePath: string = 'package.json' | ||
) {} | ||
|
||
private readVersion(): string { | ||
const jsonContent = readFileSync(resolve(this.filePath), 'utf-8'); | ||
const importedContent: unknown = JSON.parse(jsonContent); | ||
|
||
if (! isPackageJSONConfig(importedContent)) { | ||
throw new Error('Failed to parse json content.'); | ||
} | ||
|
||
return importedContent.version; | ||
} | ||
|
||
public getName(): string { | ||
return '--version'; | ||
} | ||
|
||
public async execute(..._parameters: string[]): Promise<void> { | ||
try { | ||
const version = this.readVersion; | ||
console.info(version); | ||
} catch (error: unknown) { | ||
console.error(`Failed to read version from ${this.filePath}`); | ||
|
||
if (error instanceof Error) { | ||
console.error(error.message); | ||
} | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
export { CLIApplication } from './cli.application.js'; | ||
export { CommandParser } from './command-parser.js'; | ||
export { HelpCommand } from './commands/help.command.js'; | ||
export { VersionCommand } from './commands/version.command.js'; | ||
export { ImportCommand } from './commands/import.command.js'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
import { CLIApplication, HelpCommand, VersionCommand, ImportCommand } from './cli/index.js'; | ||
|
||
const bootstrap = () => { | ||
const cliApplication = new CLIApplication(); | ||
cliApplication.registerCommands([new HelpCommand(), new VersionCommand(), new ImportCommand()]); | ||
|
||
cliApplication.processCommand(process.argv); | ||
}; | ||
|
||
bootstrap(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
export interface FileReader { | ||
read(): void; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
export { TSVFileReader } from './tsv-file-reader.js'; | ||
export { FileReader } from './file-reader.interface.js'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
import { readFileSync } from 'node:fs'; | ||
import { FileReader } from './index.js'; | ||
import { Offer, TypeUser } from '../../types/index.js'; | ||
export class TSVFileReader implements FileReader { | ||
private rawData = ''; | ||
|
||
constructor( | ||
private readonly filename: string | ||
) {} | ||
|
||
private parseRawDataToOffers(): Offer[] { | ||
return this.rawData | ||
.split('\n') | ||
.filter((row) => row.trim().length > 0) | ||
.map((line) => this.parseLineToOffer(line)); | ||
} | ||
|
||
private parseLineToOffer(line: string): Offer { | ||
const [ | ||
title, | ||
description, | ||
date, | ||
city, | ||
previewImage, | ||
images, | ||
isFavorite, | ||
isPremium, | ||
rating, | ||
type, | ||
bedrooms, | ||
maxAdults, | ||
price, | ||
goods, | ||
name, | ||
email, | ||
avatarUser, | ||
password, | ||
typeUser, | ||
] = line.split('\t'); | ||
|
||
return { | ||
title, | ||
description, | ||
postDate: new Date(date), | ||
city, | ||
previewImage, | ||
images: this.parseImages(images), | ||
isFavorite: this.parseBoolean(isFavorite), | ||
isPremium: this.parseBoolean(isPremium), | ||
rating: this.parseStringToNumber(rating), | ||
type, | ||
bedrooms: this.parseStringToNumber(bedrooms), | ||
maxAdults: this.parseStringToNumber(maxAdults), | ||
price: this.parseStringToNumber(price), | ||
goods: this.parseGoods(goods), | ||
host: this.parseHost(name, email, avatarUser, password, typeUser) | ||
}; | ||
} | ||
|
||
private parseBoolean(itemString: string): boolean { | ||
if (itemString === 'true') { | ||
return true; | ||
} | ||
return false; | ||
} | ||
|
||
private parseStringToNumber(itemString: string): number { | ||
return Number.parseInt(itemString, 10); | ||
} | ||
|
||
private parseGoods(goods: string): {good: string}[] { | ||
return goods.split(',').map((good) => ({good})); | ||
} | ||
|
||
private parseImages(images: string): {img: string}[] { | ||
return images.split(',').map((img) => ({img})); | ||
} | ||
|
||
private parseHost(name: string, email: string, avatarUser: string, password: string, typeUser: string) { | ||
return {name, email, avatarUser, password, typeUser:TypeUser[typeUser as 'Pro' | 'Usual']}; | ||
} | ||
|
||
private validateRawData(): void { | ||
if (! this.rawData) { | ||
throw new Error('File was not read'); | ||
} | ||
} | ||
|
||
public read(): void { | ||
this.rawData = readFileSync(this.filename, 'utf-8'); | ||
} | ||
|
||
public toArray(): Offer[] { | ||
this.validateRawData(); | ||
return this.parseRawDataToOffers(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
export { Offer } from './offer-type.js'; | ||
export { TypeUser, User} from './user-type.js'; |
Oops, something went wrong.