/* * Copyright 2014 Groupon, Inc * * Groupon licenses this file to you 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.killbill.automaton; import com.google.common.base.Predicate; import com.google.common.collect.ImmutableList; import com.google.common.collect.Iterables; import org.killbill.xmlloader.ValidationErrors; import javax.xml.bind.annotation.*; import java.net.URI; @XmlRootElement(name = "stateMachineConfig") @XmlAccessorType(XmlAccessType.NONE) public class DefaultStateMachineConfig extends StateMachineValidatingConfig<DefaultStateMachineConfig> implements StateMachineConfig { @XmlElementWrapper(name = "stateMachines", required = true) @XmlElement(name = "stateMachine", required = true) private DefaultStateMachine[] stateMachines; @XmlElementWrapper(name = "linkStateMachines", required = false) @XmlElement(name = "linkStateMachine", required = false) private DefaultLinkStateMachine[] linkStateMachines = new DefaultLinkStateMachine[0]; @Override public void initialize(final DefaultStateMachineConfig root, final URI uri) { for (final DefaultStateMachine cur : stateMachines) { cur.initialize(root, uri); } for (final DefaultLinkStateMachine cur : linkStateMachines) { cur.initialize(root, uri); } } @Override public ValidationErrors validate(final DefaultStateMachineConfig root, final ValidationErrors errors) { validateCollection(root, errors, stateMachines); validateCollection(root, errors, linkStateMachines); return errors; } @Override public StateMachine getStateMachine(final String stateMachineName) throws MissingEntryException { return (StateMachine) getEntry(stateMachines, stateMachineName); } @Override public LinkStateMachine getLinkStateMachine(final String linkStateMachineName) throws MissingEntryException { return (LinkStateMachine) getEntry(linkStateMachines, linkStateMachineName); } @Override public LinkStateMachine[] getLinkStateMachines() { return linkStateMachines; } @Override public StateMachine getStateMachineForState(final String stateName) throws MissingEntryException { for (final DefaultStateMachine cur : stateMachines) { for (final State st : cur.getStates()) { if (st.getName().equals(stateName)) { return cur; } } } throw new MissingEntryException("Cannot find stateMachine associated with state" + stateName); } public DefaultStateMachine[] getStateMachines() { return stateMachines; } public void setStateMachines(final DefaultStateMachine[] stateMachines) { this.stateMachines = stateMachines; } public void setLinkStateMachines(final DefaultLinkStateMachine[] linkStateMachines) { this.linkStateMachines = linkStateMachines; } public LinkStateMachine findLinkStateMachine(final StateMachine srcStateMachine, final State srcState, final StateMachine dstStateMachine) throws MissingEntryException { try { return Iterables.tryFind(ImmutableList.<LinkStateMachine>copyOf(linkStateMachines), new Predicate<LinkStateMachine>() { @Override public boolean apply(final LinkStateMachine input) { return input.getInitialStateMachine().getName().equals(srcStateMachine.getName()) && input.getInitialState().getName().equals(srcState.getName()) && input.getFinalStateMachine().getName().equals(dstStateMachine.getName()); } }).get(); } catch (final IllegalStateException e) { throw new MissingEntryException("Missing transition for srcStateMachine " + srcStateMachine.getName() + ", srcState = " + srcState.getName() + ", dstStateMachine = " + dstStateMachine.getName(), e); } } }