/** * Copyright 2010 JBoss Inc * * 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 org.drools.audit.event; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; public class RuleFlowVariableLogEvent extends RuleFlowLogEvent { private String variableId; private String variableInstanceId; private String objectToString; /** * Create a new ruleflow variable log event. */ public RuleFlowVariableLogEvent(final int type, final String variableId, final String variableInstanceId, final String processId, final String processName, final long processInstanceId, final String objectToString) { super( type, processId, processName, processInstanceId ); this.variableId = variableId; this.variableInstanceId = variableInstanceId; this.objectToString = objectToString; } public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { super.readExternal(in); variableId = (String) in.readObject(); variableInstanceId = (String) in.readObject(); objectToString = (String) in.readObject(); } public void writeExternal(ObjectOutput out) throws IOException { super.writeExternal(out); out.writeObject(variableId); out.writeObject(variableInstanceId); out.writeObject(objectToString); } public String getVariableId() { return variableId; } public String getVariableInstanceId() { return variableInstanceId; } public String getObjectToString() { return objectToString; } public String toString() { String msg = null; switch ( this.getType() ) { case BEFORE_VARIABLE_INSTANCE_CHANGED : msg = "BEFORE RULEFLOW VARIABLE CHANGED"; break; case AFTER_VARIABLE_INSTANCE_CHANGED : msg = "AFTER RULEFLOW VARIABLE CHANGED"; break; default: return super.toString(); } return msg + " " + variableId + "=" + objectToString + " process:" + getProcessName() + "[id=" + getProcessId() + "]"; } }