/** * Implement in your project. * * @return Qualifier which can specify this installation, like version + flavor. */ public String provideQualifier(){ return"unknown"; }
/** * Implement in your project. * * @return user id */ public String provideUid(){ return"uid"; }
/** * Network type * * @return {@link String} like 2G, 3G, 4G, wifi, etc. */ public String provideNetworkType(){ return"unknown"; }
/** * Config monitor duration, after this time BlockCanary will stop, use * with {@code BlockCanary}'s isMonitorDurationEnd * * @return monitor last duration (in hour) */ publicintprovideMonitorDuration(){ return-1; }
/** * Config block threshold (in millis), dispatch over this duration is regarded as a BLOCK. You may set it * from performance of device. * * @return threshold in mills */ publicintprovideBlockThreshold(){ return500; }
/** * Thread stack dump interval, use when block happens, BlockCanary will dump on main thread * stack according to current sample cycle. * <p> * Because the implementation mechanism of Looper, real dump interval would be longer than * the period specified here (especially when cpu is busier). * </p> * * @return dump interval (in millis) */ publicintprovideDumpInterval(){ returnprovideBlockThreshold(); }
/** * Path to save log, like "/blockcanary/", will save to sdcard if can. * * @return path of log files */ public String providePath(){ return"/blockcanary/"; }
/** * If need notification to notice block. * * @return true if need, else if not need. */ public boolean displayNotification(){ returntrue; }
/** * Implement in your project, bundle files into a zip file. * * @param src files before compress * @param dest files compressed * @return true if compression is successful */ public boolean zip(File[] src, File dest){ returnfalse; }
/** * Implement in your project, bundled log files. * * @param zippedFile zipped file */ publicvoidupload(File zippedFile){ thrownewUnsupportedOperationException(); }
/** * Packages that developer concern, by default it uses process name, * put high priority one in pre-order. * * @return null if simply concern only package with process name. */ public List<String> concernPackages(){ return null; }
/** * Filter stack without any in concern package, used with @{code concernPackages}. * * @return true if filter, false it not. */ public boolean filterNonConcernStack(){ returnfalse; }
/** * Provide white list, entry in white list will not be shown in ui list. * * @return return null if you don't need white-list filter. */ public List<String> provideWhiteList(){ LinkedList<String> whiteList = new LinkedList<>(); whiteList.add("org.chromium"); return whiteList; }
/** * Whether to delete files whose stack is in white list, used with white-list. * * @return true if delete, false it not. */ public boolean deleteFilesInWhiteList(){ returntrue; }
/** * Block interceptor, developer may provide their own actions. */ publicvoidonBlock(Context context, BlockInfo blockInfo){ Log.i("lz","blockInfo "+blockInfo.toString()); } }