X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fcharging-station%2Fui-server%2FUIServerFactory.ts;h=fe2b36d22a3f39375800447beb895448e1cabd77;hb=b5977da89e7a5d292b060c7af75802ee207eb2cc;hp=612054f692caee075917e873f293f14c68f2a8aa;hpb=17bc43d765c22c8d8c132484f8dc9c3edd370d91;p=e-mobility-charging-stations-simulator.git diff --git a/src/charging-station/ui-server/UIServerFactory.ts b/src/charging-station/ui-server/UIServerFactory.ts index 612054f6..fe2b36d2 100644 --- a/src/charging-station/ui-server/UIServerFactory.ts +++ b/src/charging-station/ui-server/UIServerFactory.ts @@ -1,32 +1,52 @@ -import chalk from 'chalk'; +import chalk from 'chalk' -import { UIServerUtils } from './UIServerUtils'; -import { ApplicationProtocol, type UIServerConfiguration } from '../../types'; -import { Configuration } from '../../utils/Configuration'; -import { type AbstractUIServer, UIHttpServer, UIWebSocketServer } from '../internal'; +import type { AbstractUIServer } from './AbstractUIServer.js' +import { UIHttpServer } from './UIHttpServer.js' +import { UIServerUtils } from './UIServerUtils.js' +import { UIWebSocketServer } from './UIWebSocketServer.js' +import { + ApplicationProtocol, + ApplicationProtocolVersion, + type UIServerConfiguration +} from '../../types/index.js' +// eslint-disable-next-line @typescript-eslint/no-extraneous-class export class UIServerFactory { - private constructor() { + private constructor () { // This is intentional } - public static getUIServerImplementation( - uiServerConfiguration?: UIServerConfiguration - ): AbstractUIServer | null { - if (UIServerUtils.isLoopback(uiServerConfiguration.options?.host) === false) { + public static getUIServerImplementation ( + uiServerConfiguration: UIServerConfiguration + ): AbstractUIServer | undefined { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + if (!UIServerUtils.isLoopback(uiServerConfiguration.options!.host!)) { console.warn( chalk.yellow( 'Loopback address not detected in UI server configuration. This is not recommended.' ) - ); + ) } - switch (uiServerConfiguration?.type ?? Configuration.getUIServer().type) { + uiServerConfiguration = { + version: ApplicationProtocolVersion.VERSION_11, + ...uiServerConfiguration + } + if ( + uiServerConfiguration.type === ApplicationProtocol.WS && + uiServerConfiguration.version !== ApplicationProtocolVersion.VERSION_11 + ) { + console.warn( + chalk.yellow( + `Only version ${ApplicationProtocolVersion.VERSION_11} is supported for WebSocket UI server. Falling back to version ${ApplicationProtocolVersion.VERSION_11}.` + ) + ) + uiServerConfiguration.version = ApplicationProtocolVersion.VERSION_11 + } + switch (uiServerConfiguration.type) { case ApplicationProtocol.WS: - return new UIWebSocketServer(uiServerConfiguration ?? Configuration.getUIServer()); + return new UIWebSocketServer(uiServerConfiguration) case ApplicationProtocol.HTTP: - return new UIHttpServer(uiServerConfiguration ?? Configuration.getUIServer()); - default: - return null; + return new UIHttpServer(uiServerConfiguration) } } }