Minor: Refactor the code-base for better organization and compartmentalization. (#934)
* Clean up unused code * Fix media player formatting issue for labels with new line characteres. * Refactor the media player handlers into a class. * More code cleanup and organize shared weather utils into distinct classes. * Flatten some nesting. * Move weather manager in dedicated class and build HTTP Utility class for Rest API calling. * Remove logs * Rebase master merge * Reorg code (WIP) * More reorg * Delete utility scripts * Reorg options * Finish moving all options over * Fix typescript issues * Update options imports to default * missed update * Screw barrel files honestly, work of the devil. * Only initialize power profiles if power-profiles-daemon is running. * Fix window positioning and weather service naming * style dir * More organization * Restructure types to be closer to their source * Remove lib types and constants * Update basic weather object to be saner with extensibility. * Service updates * Fix initialization strategy for services. * Fix Config Manager to only emit changed objects and added missing temp converters. * Update storage service to handle unit changes. * Added cpu temp sensor auto-discovery * Added missing JSDocs to services * remove unused * Migrate to network service. * Fix network password issue. * Move out password input into helper * Rename password mask constant to be less double-negativey. * Dropdown menu rename * Added a component to edit JSON in the settings dialog (rough/WIP) * Align settings * Add and style JSON Editor. * Adjust padding * perf(shortcuts): ⚡ avoid unnecessary polling when shortcuts are disabled Stops the recording poller when shortcuts are disabled, preventing redundant polling and reducing resource usage. * Fix types and return value if shortcut not enabled. * Move the swww daemon checking process outside of the wallpaper service into a dedicated deamon lifecyle processor. * Add more string formatters and use title case for weather status (as it was). * Fix startup errors. * Rgba fix * Remove zod from dependencies --------- Co-authored-by: KernelDiego <gonzalezdiego.contact@gmail.com>
This commit is contained in:
89
src/services/cli/commander/RequestHandler.ts
Normal file
89
src/services/cli/commander/RequestHandler.ts
Normal file
@@ -0,0 +1,89 @@
|
||||
import { CommandParser } from './Parser';
|
||||
import { ResponseCallback } from './types';
|
||||
|
||||
/**
|
||||
* The RequestHandler orchestrates the parsing and execution of commands:
|
||||
* 1. Uses the CommandParser to parse the input into a command and args.
|
||||
* 2. Invokes the command handler with the parsed arguments.
|
||||
* 3. Handles any errors and passes the result back via the response callback.
|
||||
*/
|
||||
export class RequestHandler {
|
||||
private _parser: CommandParser;
|
||||
|
||||
/**
|
||||
* Creates an instance of RequestHandler.
|
||||
*
|
||||
* @param parser - The CommandParser instance to use.
|
||||
*/
|
||||
constructor(parser: CommandParser) {
|
||||
this._parser = parser;
|
||||
}
|
||||
|
||||
/**
|
||||
* Initializes the request handler with the given input and response callback.
|
||||
*
|
||||
* @param input - The input string to process.
|
||||
* @param response - The callback to handle the response.
|
||||
* @returns A promise that resolves when the request is handled.
|
||||
*/
|
||||
public async initializeRequestHandler(input: string, response: ResponseCallback): Promise<void> {
|
||||
try {
|
||||
const parsed = this._parser.parse(input);
|
||||
const { command, args } = parsed;
|
||||
|
||||
const result = command.handler(args);
|
||||
if (result instanceof Promise) {
|
||||
const resolved = await result;
|
||||
response(this._formatOutput(resolved));
|
||||
} else {
|
||||
response(this._formatOutput(result));
|
||||
}
|
||||
} catch (error) {
|
||||
response(this._formatError(error));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Formats the output based on its type.
|
||||
*
|
||||
* @param output - The output to format.
|
||||
* @returns A string representation of the output.
|
||||
*/
|
||||
private _formatOutput(output: unknown): string {
|
||||
if (typeof output === 'string') {
|
||||
return output;
|
||||
} else if (typeof output === 'number' || typeof output === 'boolean') {
|
||||
return output.toString();
|
||||
} else if (typeof output === 'object' && output !== null) {
|
||||
try {
|
||||
return JSON.stringify(output, null, 2);
|
||||
} catch {
|
||||
return 'Unable to display object.';
|
||||
}
|
||||
} else {
|
||||
return String(output);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Formats the error based on its type.
|
||||
*
|
||||
* @param error - The error to format.
|
||||
* @returns A string representation of the error.
|
||||
*/
|
||||
private _formatError(error: unknown): string {
|
||||
if (error instanceof Error) {
|
||||
return `Error: ${error.message}`;
|
||||
} else if (typeof error === 'string') {
|
||||
return `Error: ${error}`;
|
||||
} else if (typeof error === 'object' && error !== null) {
|
||||
try {
|
||||
return `Error: ${JSON.stringify(error, null, 2)}`;
|
||||
} catch {
|
||||
return 'An unknown error occurred.';
|
||||
}
|
||||
} else {
|
||||
return `Error: ${String(error)}`;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user