com.aspectran.core.activity.Activity Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2017 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.core.activity;
import com.aspectran.core.activity.process.result.ProcessResult;
import com.aspectran.core.adapter.ApplicationAdapter;
import com.aspectran.core.adapter.RequestAdapter;
import com.aspectran.core.adapter.ResponseAdapter;
import com.aspectran.core.adapter.SessionAdapter;
import com.aspectran.core.component.bean.BeanRegistry;
import com.aspectran.core.component.template.TemplateProcessor;
import com.aspectran.core.context.ActivityContext;
import com.aspectran.core.context.env.Environment;
import com.aspectran.core.context.rule.AspectAdviceRule;
import com.aspectran.core.context.rule.AspectRule;
import com.aspectran.core.context.rule.ExceptionRule;
import com.aspectran.core.context.rule.type.MethodType;
import java.util.List;
/**
* The Interface Activity.
*
* Created: 2008. 03. 22 PM 5:48:09
*/
public interface Activity extends BeanRegistry {
/**
* Prepare for the activity.
*
* @param transletName the translet name
*/
void prepare(String transletName);
/**
* Prepare for the activity.
*
* @param transletName the translet name
* @param requestMethod the request method
*/
void prepare(String transletName, String requestMethod);
/**
* Prepare for the activity.
*
* @param transletName the translet name
* @param requestMethod the request method
*/
void prepare(String transletName, MethodType requestMethod);
/**
* Performs the prepared activity.
*/
void perform();
/**
* Performs the prepared activity but does not respond to the client.
*/
void performWithoutResponse();
/**
* Finish the current activity.
* It must be called to finish the activity.
*/
void finish();
/**
* Throws an ActivityTerminatedException to terminate the current activity.
*
* @throws ActivityTerminatedException if an activity terminated without completion
*/
void terminate();
/**
* Throws an ActivityTerminatedException with the reason for terminating the current activity.
*
* @param cause the termination cause
* @throws ActivityTerminatedException the exception to terminate activity
*/
void terminate(String cause);
/**
* Returns the request method.
*
* @return the request method
*/
MethodType getRequestMethod();
/**
* Returns the name of the current translet.
*
* @return the translet name
*/
String getTransletName();
/**
* Returns an instance of the current translet.
*
* @return an instance of the current translet
*/
Translet getTranslet();
/**
* Returns the process result.
*
* @return the process result
*/
ProcessResult getProcessResult();
/**
* Returns an action result for the specified action id from the process result,
* or {@code null} if the action does not exist.
*
* @param actionId the specified action id
* @return an action result
*/
Object getProcessResult(String actionId);
/**
* Execute aspect advices with given rules.
*
* @param aspectAdviceRuleList the aspect advice rules
*/
void executeAdvice(List aspectAdviceRuleList);
/**
* Execute aspect advices with given rules, and does not raise exceptions.
*
* @param aspectAdviceRuleList the aspect advice rules
*/
void executeAdviceWithoutThrow(List aspectAdviceRuleList);
/**
* Executes an aspect advice with a given rule.
*
* @param aspectAdviceRule the aspect advice rule
*/
void executeAdvice(AspectAdviceRule aspectAdviceRule);
/**
* Executes an aspect advice with a given rule and does not raise an exception.
*
* @param aspectAdviceRule the aspect advice rule
*/
void executeAdviceWithoutThrow(AspectAdviceRule aspectAdviceRule);
/**
* Returns whether the response is reserved.
*
* @return true, if the response is reserved
*/
boolean isResponseReserved();
/**
* Exception handling.
*
* @param exceptionRuleList the exception rule list
*/
void handleException(List exceptionRuleList);
/**
* Returns whether the exception was thrown.
*
* @return true, if is exception raised
*/
boolean isExceptionRaised();
/**
* Returns an instance of the currently raised exception.
*
* @return an instance of the currently raised exception
*/
Throwable getRaisedException();
/**
* Returns the innermost one of the chained (wrapped) exceptions.
*
* @return the innermost one of the chained (wrapped) exceptions
*/
Throwable getRootCauseOfRaisedException();
/**
* Sets an instance of the currently raised exception.
*
* @param raisedException an instance of the currently raised exception
*/
void setRaisedException(Throwable raisedException);
/**
* Gets the activity context.
*
* @return the activity context
*/
ActivityContext getActivityContext();
/**
* Returns the environment of the current activity context.
*
* @return the environment
*/
Environment getEnvironment();
/**
* Create a new inner activity.
*
* @param the type of the activity
* @return the activity object
*/
T newActivity();
/**
* Gets the application adapter.
*
* @return the application adapter
*/
ApplicationAdapter getApplicationAdapter();
/**
* Gets the session adapter.
*
* @return the session adapter
*/
SessionAdapter getSessionAdapter();
/**
* Gets the request adapter.
*
* @return the request adapter
*/
RequestAdapter getRequestAdapter();
/**
* Gets the response adapter.
*
* @return the response adapter
*/
ResponseAdapter getResponseAdapter();
/**
* Gets the bean registry.
*
* @return the bean registry
*/
BeanRegistry getBeanRegistry();
/**
* Gets the template processor.
*
* @return the template processor
*/
TemplateProcessor getTemplateProcessor();
/**
* Gets the setting value in the translet scope.
*
* @param the type of the value
* @param settingName the setting name
* @return the setting value
*/
T getSetting(String settingName);
/**
* Register an aspect rule dynamically.
*
* @param aspectRule the aspect rule
*/
void registerAspectRule(AspectRule aspectRule);
/**
* Gets the aspect advice bean.
*
* @param the type of the bean
* @param aspectId the aspect id
* @return the aspect advice bean object
*/
T getAspectAdviceBean(String aspectId);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy