/* * Copyright 2006-2012 Amazon Technologies, Inc. or its affiliates. * Amazon, Amazon.com and Carbonado are trademarks or registered trademarks * of Amazon Technologies, Inc. or its affiliates. All rights reserved. * * 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.amazon.carbonado.repo.logging; import com.amazon.carbonado.FetchException; import com.amazon.carbonado.PersistException; import com.amazon.carbonado.Query; import com.amazon.carbonado.Storable; import com.amazon.carbonado.Storage; import com.amazon.carbonado.Trigger; import com.amazon.carbonado.filter.Filter; /** * * * @author Brian S O'Neill */ class LoggingStorage implements Storage { private final Storage mStorage; final Log mLog; LoggingStorage(LoggingRepository repo, Storage storage) { mStorage = storage; mLog = repo.getLog(); storage.addTrigger(new LoggingTrigger(mLog)); } public Class getStorableType() { return mStorage.getStorableType(); } public S prepare() { return mStorage.prepare(); } public Query query() throws FetchException { return new LoggingQuery(this, mStorage.query()); } public Query query(String filter) throws FetchException { return new LoggingQuery(this, mStorage.query(filter)); } public Query query(Filter filter) throws FetchException { return new LoggingQuery(this, mStorage.query(filter)); } /** * @since 1.2 */ public void truncate() throws PersistException { if (mLog.isEnabled()) { mLog.write("Storage.truncate() on " + getStorableType().getClass()); } mStorage.truncate(); } public boolean addTrigger(Trigger trigger) { return mStorage.addTrigger(trigger); } public boolean removeTrigger(Trigger trigger) { return mStorage.removeTrigger(trigger); } protected Query wrap(Query query) { return new LoggingQuery(this, query); } private static class LoggingTrigger extends Trigger { private final Log mLog; LoggingTrigger(Log log) { mLog = log; } @Override public Object beforeInsert(S storable) { if (mLog.isEnabled()) { mLog.write("Storable.insert() on " + storable.toString()); } return null; } @Override public Object beforeTryInsert(S storable) { if (mLog.isEnabled()) { mLog.write("Storable.tryInsert() on " + storable.toString()); } return null; } @Override public Object beforeUpdate(S storable) { if (mLog.isEnabled()) { mLog.write("Storable.update() on " + storable.toString()); } return null; } @Override public Object beforeTryUpdate(S storable) { if (mLog.isEnabled()) { mLog.write("Storable.tryUpdate() on " + storable.toString()); } return null; } @Override public Object beforeDelete(S storable) { if (mLog.isEnabled()) { mLog.write("Storable.delete() on " + storable.toString()); } return null; } @Override public Object beforeTryDelete(S storable) { if (mLog.isEnabled()) { mLog.write("Storable.tryDelete() on " + storable.toString()); } return null; } @Override public void afterLoad(S storable) { if (mLog.isEnabled()) { mLog.write("Loaded " + storable.toString()); } } } }