/*! * @license * Copyright 2019 Alfresco Software, Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* eslint-disable @typescript-eslint/naming-convention */ import { PluginInterface } from './plugin-model'; import { logger } from '../logger'; import { ProcessAutomationHealth } from './process-automation-health'; export class ProcessAutomationCheckPlugin { processAutomationHealth: ProcessAutomationHealth; constructor( private plugInInfo: PluginInterface, private alfrescoJsApi: any ) { this.processAutomationHealth = new ProcessAutomationHealth( this.plugInInfo, this.alfrescoJsApi ); } async checkProcessAutomationPlugin() { let pluginStatus; try { const isPluginEnabled = await this.processAutomationHealth.isPluginEnabledFromAppConfiguration(); const isBackendActive = await this.processAutomationHealth.checkBackendHealth(); if (isPluginEnabled && isBackendActive) { logger.info( `The plugin ${ this.plugInInfo.name } has been correctly configured` ); pluginStatus = [{ PluginName: this.plugInInfo.name, Status: 'Active', BE: 'UP', FE: 'Enabled' }]; console.table(pluginStatus); } else { this.logConfigurationError(); pluginStatus = [{ PluginName: this.plugInInfo.name, Status: 'Inactive', BE: isBackendActive ? 'UP' : 'DOWN', FE: isPluginEnabled ? 'Enabled' : 'Disabled' }]; console.table(pluginStatus); process.exit(1); } } catch (e) { this.logConfigurationError(e); pluginStatus = [{ PluginName: this.plugInInfo.name, Status: 'Inactive', BE: 'DOWN', FE: 'Disabled' }]; console.table(pluginStatus); process.exit(1); } } private logConfigurationError(error?: any) { logger.error( `The plugin ${ this.plugInInfo.name } has not been correctly configured`, error ); } }