/* * Copyright (c) 1998-2011 Caucho Technology -- all rights reserved * * This file is part of Resin(R) Open Source * * Each copy or derived work must preserve the copyright notice and this * notice unmodified. * * Resin Open Source is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * Resin Open Source is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty * of NON-INFRINGEMENT. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with Resin Open Source; if not, write to the * Free Software Foundation, Inc. * 59 Temple Place, Suite 330 * Boston, MA 02111-1307 USA * * @author Scott Ferguson */ package com.caucho.amber.entity; import com.caucho.amber.query.ResultSetCacheChunk; import com.caucho.amber.type.EntityType; import com.caucho.util.L10N; import com.caucho.util.Log; import java.util.logging.Level; import java.util.logging.Logger; /** * Code to update the cache value on the completion of a transaction. */ public class RowInvalidateCompletion implements AmberCompletion { private static final L10N L = new L10N(RowInvalidateCompletion.class); private static final Logger log = Log.open(RowInvalidateCompletion.class); private String _table; private Object _key; public RowInvalidateCompletion(String table, Object key) { if (log.isLoggable(Level.FINER)) log.log(Level.FINER, L.l("RowInvalidateCompletion table: {0} key: {1}", table, key)); if (table == null || key == null) throw new NullPointerException(); _table = table; _key = key; } /** * Code when the transaction completes. * * @return true if the entry should be deleted. */ public boolean complete(EntityType entityType, Object key, EntityItem entityItem) { if (log.isLoggable(Level.FINER)) log.log(Level.FINER, L.l("RowInvalidateCompletion.complete")); if (entityType.getTable().getName().equals(_table) && _key.equals(key)) { if (log.isLoggable(Level.FINER)) log.log(Level.FINER, L.l("RowInvalidateCompletion expiring table: {0} key: {1}", _table, _key)); // jpa/0k20 entityItem.expire(); } else { entityItem.getEntity().__caucho_invalidate_foreign(_table, key); } return false; } /** * Code to invalidate the query. * * @return true if the entry should be deleted. */ public boolean complete(ResultSetCacheChunk chunk) { if (chunk.invalidate(_table, _key)) { chunk.invalidate(); return true; } return false; } /** * Returns true for equality. */ public boolean equals(Object o) { if (this == o) return true; else if (o == null || o.getClass() != getClass()) return false; RowInvalidateCompletion comp = (RowInvalidateCompletion) o; return _table.equals(comp._table) && _key.equals(comp._key); } public String toString() { return "RowInvalidateCompletion[" + _table + "," + _key + "]"; } }