All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aspectran.shell.service.AbstractShellService Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2008-2025 The Aspectran Project
 *
 * 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.
 */
package com.aspectran.shell.service;

import com.aspectran.core.adapter.SessionAdapter;
import com.aspectran.core.component.session.DefaultSessionManager;
import com.aspectran.core.component.session.SessionAgent;
import com.aspectran.core.component.session.SessionManager;
import com.aspectran.core.context.asel.token.Token;
import com.aspectran.core.context.asel.token.TokenEvaluator;
import com.aspectran.core.context.asel.token.TokenParser;
import com.aspectran.core.context.config.AcceptableConfig;
import com.aspectran.core.context.config.AspectranConfig;
import com.aspectran.core.context.config.SessionManagerConfig;
import com.aspectran.core.context.config.ShellConfig;
import com.aspectran.core.service.CoreServiceException;
import com.aspectran.core.service.DefaultCoreService;
import com.aspectran.core.service.RequestAcceptor;
import com.aspectran.shell.adapter.ShellSessionAdapter;
import com.aspectran.shell.console.ShellConsole;
import com.aspectran.utils.Assert;
import com.aspectran.utils.StringUtils;
import com.aspectran.utils.annotation.jsr305.NonNull;
import com.aspectran.utils.logging.Logger;
import com.aspectran.utils.logging.LoggerFactory;

/**
 * Abstract base class for {@code ShellService} implementations.
 *
 * 

Created: 2017. 10. 30.

*/ public abstract class AbstractShellService extends DefaultCoreService implements ShellService { private static final Logger logger = LoggerFactory.getLogger(AbstractShellService.class); private final ShellConsole console; private SessionManager sessionManager; private SessionAgent sessionAgent; /** If verbose mode is on, a detailed description is printed each time the command is executed. */ private boolean verbose; private String greetings; private Token[] greetingsTokens; AbstractShellService(ShellConsole console) { super(); Assert.notNull(console, "console must not be null"); this.console = console; } @Override public void afterContextLoaded() throws Exception { super.afterContextLoaded(); parseGreetings(); } @Override public ShellConsole getConsole() { return console; } /** * Tests if the verbose mode is enabled. * If verbose mode is on, a detailed description is printed each time the command is executed. * Returns a flag indicating whether to show the description or not. * @return true if the verbose mode is enabled */ @Override public boolean isVerbose() { return verbose; } /** * Enables or disables the verbose mode. * If verbose mode is on, a detailed description is printed each time the command is executed. * Sets a flag indicating whether to show the description or not. * @param verbose true to enable the verbose mode; false to disable */ @Override public void setVerbose(boolean verbose) { this.verbose = verbose; } @Override public String getGreetings() { return greetings; } @Override public void setGreetings(String greetings) { this.greetings = greetings; } @Override public void printGreetings() { if (greetingsTokens != null) { TokenEvaluator evaluator = getDefaultActivity().getTokenEvaluator(); String message = evaluator.evaluateAsString(greetingsTokens); if (console.isReading()) { console.clearLine(); } console.writeLine(message); } else if (greetings != null) { if (console.isReading()) { console.clearLine(); } console.writeLine(greetings); } } private void parseGreetings() { if (StringUtils.hasText(greetings)) { greetingsTokens = TokenParser.makeTokens(greetings, true); if (greetingsTokens != null) { try { for (Token token : greetingsTokens) { Token.resolveAlternativeValue(token, getServiceClassLoader()); } } catch (Exception e) { greetingsTokens = null; logger.error("Failed to parse greetings", e); } } } } @Override public void printHelp() { if (isVerbose()) { String description = getActivityContext().getDescription(); if (description != null) { console.writeLine(description); } } } @Override public SessionAdapter newSessionAdapter() { if (sessionAgent != null) { return new ShellSessionAdapter(sessionAgent); } else { return null; } } protected void createSessionManager() { Assert.state(this.sessionManager == null, "Session Manager is already exists for shell service"); ShellConfig shellConfig = getAspectranConfig().getShellConfig(); if (shellConfig != null) { SessionManagerConfig sessionManagerConfig = shellConfig.getSessionManagerConfig(); if (sessionManagerConfig != null && sessionManagerConfig.isEnabled()) { try { DefaultSessionManager sessionManager = new DefaultSessionManager(); sessionManager.setActivityContext(getActivityContext()); sessionManager.setSessionManagerConfig(sessionManagerConfig); sessionManager.initialize(); this.sessionManager = sessionManager; this.sessionAgent = new SessionAgent(sessionManager.getSessionHandler()); } catch (Exception e) { throw new CoreServiceException("Failed to create session manager for shell service", e); } } } } protected void destroySessionManager() { if (sessionAgent != null) { sessionAgent.invalidate(); sessionAgent = null; } if (sessionManager != null) { sessionManager.destroy(); sessionManager = null; } } @Override public void restart(String message) throws Exception { if (StringUtils.hasText(message)) { console.setStyle(console.getDangerStyle()); console.writeAbove(message); console.resetStyle(); } if (!isBusy() && console.confirmRestart()) { try { super.restart(message); } catch (Exception e) { logger.error("Shell restart failed", e); console.setStyle(console.getDangerStyle()); console.writeAbove("Shell restart failed!"); console.resetStyle(); } if (console.isReading()) { console.redrawLine(); } } } @Override public boolean isBusy() { return console.isReading(); } @Override protected void configure(@NonNull AspectranConfig aspectranConfig) { ShellConfig shellConfig = aspectranConfig.getShellConfig(); if (shellConfig != null) { configure(shellConfig); } super.configure(aspectranConfig); } private void configure(@NonNull ShellConfig shellConfig) { setVerbose(shellConfig.isVerbose()); setGreetings(shellConfig.getGreetings()); AcceptableConfig acceptableConfig = shellConfig.getAcceptableConfig(); if (acceptableConfig != null) { setRequestAcceptor(new RequestAcceptor(acceptableConfig)); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy