com.salesforce.ide.core.internal.aspects.CrudOperationsRetryAspect.java Source code

Java tutorial

Introduction

Here is the source code for com.salesforce.ide.core.internal.aspects.CrudOperationsRetryAspect.java

Source

/*******************************************************************************
 * Copyright (c) 2014 Salesforce.com, inc..
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 * 
 * Contributors:
 *     Salesforce.com, inc. - initial API and implementation
 ******************************************************************************/
package com.salesforce.ide.core.internal.aspects;

import org.apache.log4j.Logger;
import org.aspectj.lang.ProceedingJoinPoint;

import com.salesforce.ide.core.remote.ForceConnectionException;

public class CrudOperationsRetryAspect extends BaseRetryAspect {

    private static final Logger logger = Logger.getLogger(CrudOperationsRetryAspect.class);

    public Object crudOperationRetry(ProceedingJoinPoint proceedingJoinPoint)
            throws ForceConnectionException, Throwable {
        int numAttempts = 0;
        ForceConnectionException forceConnectionException = null;
        do {
            numAttempts++;

            if (logger.isDebugEnabled()) {
                logger.debug("Attempt [" + numAttempts + "] at executing:\n '"
                        + proceedingJoinPoint.getSignature().toLongString() + "'");
            }

            try {
                return proceedingJoinPoint.proceed();
            } catch (ForceConnectionException ex) {
                evaluateOperationsException(ex, proceedingJoinPoint);
                forceConnectionException = ex;
            }
        } while (numAttempts <= this.maxRetries);

        logger.warn("Max retries reached.");

        throw forceConnectionException;
    }
}