ingo@219: /* ingo@219: * Copyright (c) 2010, 2011 by Intevation GmbH ingo@219: * ingo@219: * This program is free software under the LGPL (>=v2.1) ingo@219: * Read the file LGPL.txt coming with the software for details ingo@219: * or visit http://www.gnu.org/licenses/ if it does not exist. ingo@219: */ ingo@219: package de.intevation.artifactdatabase; ingo@219: ingo@219: import org.apache.log4j.Logger; ingo@219: ingo@219: import de.intevation.artifacts.CallMeta; ingo@219: ingo@219: import de.intevation.artifactdatabase.Backend.PersistentArtifact; ingo@219: ingo@219: ingo@219: /** ingo@219: * Class that implements the call context handed to the methods calls ingo@219: * describe(), feed(), etc. of the artifact. ingo@219: * ingo@219: * @author Sascha L. Teichmann ingo@219: */ ingo@219: public class ArtifactCallContext extends AbstractCallContext { ingo@219: ingo@219: private static Logger logger = Logger.getLogger(ArtifactCallContext.class); ingo@219: ingo@219: ingo@219: /** ingo@219: * Error message issued if an artifact wants to translate itself ingo@219: * into a none valid persistent state. ingo@219: */ ingo@219: public static final String INVALID_CALL_STATE = "Invalid after call state"; ingo@219: ingo@219: /** ingo@219: * Error message issued if one tries to remove a requested artifact ingo@219: * from the list of artifacts running in background which is ingo@219: * not in this list. ingo@219: */ ingo@219: public static final String NOT_IN_BACKGROUND = "Not in background"; ingo@219: ingo@219: ingo@219: /** ingo@219: * The persistence wrapper around the living artifact ingo@219: */ ingo@219: protected PersistentArtifact artifact; ingo@219: ingo@219: ingo@219: public ArtifactCallContext( ingo@219: ArtifactDatabaseImpl artifactDatabase, ingo@219: int action, ingo@219: CallMeta callMeta, ingo@219: Object context, ingo@219: PersistentArtifact artifact) ingo@219: { ingo@219: super(artifactDatabase, action, callMeta, context); ingo@219: ingo@219: this.artifact = artifact; ingo@219: } ingo@219: ingo@219: ingo@219: public void afterCall(int action) { ingo@219: this.action = action; ingo@219: if (action == BACKGROUND) { ingo@219: database.addIdToBackground(artifact.getId()); ingo@219: } ingo@219: } ingo@219: ingo@219: ingo@219: public void afterBackground(int action) { ingo@219: if (this.action != BACKGROUND) { ingo@219: throw new IllegalStateException(NOT_IN_BACKGROUND); ingo@219: } ingo@219: database.fromBackground(artifact, action); ingo@219: } ingo@219: ingo@219: ingo@219: public Long getTimeToLive() { ingo@219: return artifact.getTTL(); ingo@219: } ingo@219: ingo@219: ingo@219: /** ingo@219: * Dispatches and executes the persistence action after ingo@219: * the return of the concrete artifact call. ingo@219: */ ingo@219: public void postCall() { ingo@219: switch (action) { ingo@219: case NOTHING: ingo@219: break; ingo@219: case TOUCH: ingo@219: artifact.touch(); ingo@219: break; ingo@219: case STORE: ingo@219: artifact.store(); ingo@219: break; ingo@219: case BACKGROUND: ingo@219: logger.warn( ingo@219: "BACKGROUND processing is not fully implemented, yet!"); ingo@219: artifact.store(); ingo@219: break; ingo@219: default: ingo@219: logger.error(INVALID_CALL_STATE + ": " + action); ingo@219: throw new IllegalStateException(INVALID_CALL_STATE); ingo@219: } ingo@219: } ingo@219: } ingo@219: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :