All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.crashnote.core.send.Sender2.jav Maven / Gradle / Ivy

///**
// * Copyright (C) 2011 - 101loops.com 
// *
// * 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.crashnote.core.send;
//
//import com.crashnote.core.Lifecycle;
//import com.crashnote.core.cache.Cache;
//import com.crashnote.core.config.*;
//import com.crashnote.core.log.LogLog;
//import com.crashnote.core.model.log.LogReport;
//import com.crashnote.core.model.types.*;
//import com.crashnote.core.send.impl.Connector;
//import com.crashnote.core.util.SystemUtil;
//
//import java.util.Date;
//
///**
// * This class handles is responsible for transmitting the crash report to the cloud server.
// * 

// * To complete this task it uses a {@link com.crashnote.core.send.impl.Connector} that handles the connection to the // * server and a {@link com.crashnote.core.cache.Cache} that holds reports that could not be transmitted yet/right now. // */ //public class Sender2 // implements Lifecycle, IConfigChangeListener { // // private Date lastFlush; // private boolean started; // // // configuration settings: // private boolean async; // private boolean retryOnFailure; // private ApplicationType appType; // // private final LogLog logger; // private final Cache cache; // private final SystemUtil sysUtil; // private final Connector connector; // // // SETUP ====================================================================================== // // public Sender2(final C config) { // updateConfig(config); // this.cache = config.getCache(); // this.sysUtil = config.getSystemUtil(); // this.connector = createConnector(config); // this.logger = config.getLogger(this.getClass()); // } // // public void updateConfig(final C config) { // config.addListener(this); // this.async = config.isAsync(); // this.appType = config.getApplicationType(); // this.retryOnFailure = config.getFailMode() == FailMode.RETRY; // } // // // LIFECYCLE ================================================================================== // // public boolean start() { // if (!started) { // started = true; // logger.debug("starting module [sender]"); // // cache.start(); // connector.start(); // } // return started; // } // // public boolean stop() { // if (started) { // started = false; // logger.debug("stopping module [sender]"); // // cache.stop(); // connector.stop(); // } // return started; // } // // // INTERFACE ================================================================================== // // public void send(final LogReport report) { // if (isAsync()) // cache(report); // ASYNC? -> move straight to cache // else // tryToSend(report); // SYNC? -> try to send // } // // /* // TODO: must be called regularly by async processor // public void flush() { // if (async && connector.isEnabled()) { // only flush cache if: async mode // lastFlush = new Date(); // // // just get up to 5 reports and transmit them // final LogReport[] reports = cache.retrieve(5); // if (reports != null) // for (final LogReport r : reports) // tryToSend(r); // } // } // */ // // // SHARED ===================================================================================== // // protected void tryToSend(final LogReport report) { // if (report != null) { // // on the client: persist it as fast as possible 'cause it might be turned off any time // if (getAppType() == ApplicationType.CLIENT) cache(report); // // if (sysUtil.isOffline()) { // cache(report); // offline? then cache it directly, no need to try! // } else { // transmit(report); // is/might be online? transmit it! // } // } // } // // protected final boolean transmit(final LogReport report) { // final boolean success = connector.transmit(report); // if (success) { // uncache(report); // } else { // if (isRetryOnFailure()) // cache(report); // ... if retry is 'on': move data to cache // else // uncache(report); // ... otherwise: remove data from cache // } // return success; // } // // protected final boolean uncache(final LogReport report) { // return cache.remove(report); // } // // protected final boolean cache(final LogReport report) { // return cache.store(report); // } // // // FACTORY ==================================================================================== // // /** // * Create a {@link com.crashnote.core.send.impl.Connector} // * // * @param config the configuration object // * @return a new instance of a Connector // */ // protected Connector createConnector(final C config) { // return new Connector(config); // // /* // if (getAppType() == ApplicationType.SERVER) { // return new ConnectorSmart(config); // } else { // return new Connector(config); // } // */ // } // // // GET ======================================================================================== // // public Date getLastFlush() { // return lastFlush; // } // // public Connector getConnector() { // return connector; // } // // public ApplicationType getAppType() { // return appType; // } // // public Boolean isRetryOnFailure() { // return retryOnFailure; // } // // public LogLog getLogger() { // return logger; // } // // public boolean isAsync() { // return async; // } //}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy