Files
custum-hyprpanel/src/services/cli/commander/RequestHandler.ts
Jas Singh 8cf5806766 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>
2025-05-26 19:45:11 -07:00

90 lines
2.9 KiB
TypeScript

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)}`;
}
}
}