react-native-nitro-background-geolocation 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/NitroBackgroundGeolocation.podspec +29 -0
- package/android/CMakeLists.txt +24 -0
- package/android/build.gradle +133 -0
- package/android/src/main/AndroidManifest.xml +65 -0
- package/android/src/main/cpp/cpp-adapter.cpp +11 -0
- package/android/src/main/java/com/margelo/nitro/nitrobackgroundgeolocation/ConfigMapper.kt +332 -0
- package/android/src/main/java/com/margelo/nitro/nitrobackgroundgeolocation/HeadlessTaskRegistry.kt +23 -0
- package/android/src/main/java/com/margelo/nitro/nitrobackgroundgeolocation/HeadlessTaskService.kt +66 -0
- package/android/src/main/java/com/margelo/nitro/nitrobackgroundgeolocation/NitroBackgroundGeolocation.kt +538 -0
- package/android/src/main/java/com/margelo/nitro/nitrobackgroundgeolocation/NitroBackgroundGeolocationPackage.kt +22 -0
- package/android/src/main/java/com/margelo/nitro/nitrobackgroundgeolocation/ReactNativeHeadlessTaskRunner.kt +62 -0
- package/android/src/main/java/com/marianhello/bgloc/BackgroundGeolocationFacade.java +542 -0
- package/android/src/main/java/com/marianhello/bgloc/BootCompletedReceiver.java +59 -0
- package/android/src/main/java/com/marianhello/bgloc/Config.java +652 -0
- package/android/src/main/java/com/marianhello/bgloc/ConnectivityListener.java +5 -0
- package/android/src/main/java/com/marianhello/bgloc/HttpPostService.java +168 -0
- package/android/src/main/java/com/marianhello/bgloc/LocationManager.java +138 -0
- package/android/src/main/java/com/marianhello/bgloc/PluginDelegate.java +19 -0
- package/android/src/main/java/com/marianhello/bgloc/PluginException.java +38 -0
- package/android/src/main/java/com/marianhello/bgloc/PostLocationTask.java +186 -0
- package/android/src/main/java/com/marianhello/bgloc/ResourceResolver.java +55 -0
- package/android/src/main/java/com/marianhello/bgloc/data/AbstractLocationTemplate.java +69 -0
- package/android/src/main/java/com/marianhello/bgloc/data/ArrayListLocationTemplate.java +88 -0
- package/android/src/main/java/com/marianhello/bgloc/data/BackgroundActivity.java +108 -0
- package/android/src/main/java/com/marianhello/bgloc/data/BackgroundLocation.java +994 -0
- package/android/src/main/java/com/marianhello/bgloc/data/ConfigurationDAO.java +13 -0
- package/android/src/main/java/com/marianhello/bgloc/data/DAOFactory.java +17 -0
- package/android/src/main/java/com/marianhello/bgloc/data/HashMapLocationTemplate.java +82 -0
- package/android/src/main/java/com/marianhello/bgloc/data/LocationDAO.java +22 -0
- package/android/src/main/java/com/marianhello/bgloc/data/LocationTemplate.java +12 -0
- package/android/src/main/java/com/marianhello/bgloc/data/LocationTemplateFactory.java +65 -0
- package/android/src/main/java/com/marianhello/bgloc/data/LocationTransform.java +19 -0
- package/android/src/main/java/com/marianhello/bgloc/data/provider/ContentProviderLocationDAO.java +395 -0
- package/android/src/main/java/com/marianhello/bgloc/data/provider/LocationContentProvider.java +321 -0
- package/android/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteConfigurationContract.java +76 -0
- package/android/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteConfigurationDAO.java +160 -0
- package/android/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteLocationContract.java +112 -0
- package/android/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteLocationDAO.java +506 -0
- package/android/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteOpenHelper.java +151 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/AbstractTaskRunner.java +15 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/ActivityTask.java +48 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/JsCallback.java +10 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/LocationTask.java +61 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/StationaryTask.java +25 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/Task.java +8 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/TaskRunner.java +5 -0
- package/android/src/main/java/com/marianhello/bgloc/headless/TaskRunnerFactory.java +8 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/AbstractLocationProvider.java +171 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/ActivityRecognitionLocationProvider.java +280 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/DistanceFilterLocationProvider.java +586 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/LocationProvider.java +32 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/LocationProviderFactory.java +47 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/ProviderDelegate.java +12 -0
- package/android/src/main/java/com/marianhello/bgloc/provider/RawLocationProvider.java +142 -0
- package/android/src/main/java/com/marianhello/bgloc/service/LocationService.java +17 -0
- package/android/src/main/java/com/marianhello/bgloc/service/LocationServiceImpl.java +760 -0
- package/android/src/main/java/com/marianhello/bgloc/service/LocationServiceInfo.java +6 -0
- package/android/src/main/java/com/marianhello/bgloc/service/LocationServiceInfoImpl.java +41 -0
- package/android/src/main/java/com/marianhello/bgloc/service/LocationServiceIntentBuilder.java +203 -0
- package/android/src/main/java/com/marianhello/bgloc/service/LocationServiceProxy.java +140 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/AccountHelper.java +39 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/Authenticator.java +68 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/AuthenticatorService.java +28 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/BatchManager.java +246 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/NotificationHelper.java +148 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/SyncAdapter.java +233 -0
- package/android/src/main/java/com/marianhello/bgloc/sync/SyncService.java +68 -0
- package/android/src/main/java/com/marianhello/logging/DBLogReader.java +203 -0
- package/android/src/main/java/com/marianhello/logging/LogEntry.java +99 -0
- package/android/src/main/java/com/marianhello/logging/LoggerManager.java +70 -0
- package/android/src/main/java/com/marianhello/logging/UncaughtExceptionLogger.java +36 -0
- package/android/src/main/java/com/marianhello/utils/CloneHelper.java +22 -0
- package/android/src/main/java/com/marianhello/utils/Convert.java +56 -0
- package/android/src/main/java/com/marianhello/utils/TextUtils.java +72 -0
- package/android/src/main/java/com/marianhello/utils/ToneGenerator.java +68 -0
- package/android/src/main/java/org/apache/commons/io/Charsets.java +153 -0
- package/android/src/main/java/org/apache/commons/io/input/ReversedLinesFileReader.java +344 -0
- package/android/src/main/java/org/chromium/content/browser/ThreadUtils.java +134 -0
- package/android/src/main/java/ru/andremoniy/sqlbuilder/SqlExpression.java +398 -0
- package/android/src/main/java/ru/andremoniy/sqlbuilder/SqlSelectStatement.java +671 -0
- package/android/src/main/java/ru/andremoniy/sqlbuilder/SqlStatement.java +29 -0
- package/android/src/main/java/ru/andremoniy/utils/TextUtils.java +61 -0
- package/android/src/main/res/values/strings.xml +6 -0
- package/android/src/main/res/xml/authenticator.xml +7 -0
- package/android/src/main/res/xml/syncadapter.xml +9 -0
- package/app.plugin.js +64 -0
- package/ios/NitroBackgroundGeolocation.swift +719 -0
- package/ios/NitroBackgroundGeolocationBootstrap.m +98 -0
- package/ios/common/BackgroundGeolocation/CocoaLumberjack.h +1945 -0
- package/ios/common/BackgroundGeolocation/CocoaLumberjack.m +5255 -0
- package/ios/common/BackgroundGeolocation/FMDB.h +2357 -0
- package/ios/common/BackgroundGeolocation/FMDB.m +2672 -0
- package/ios/common/BackgroundGeolocation/FMDBLogger.h +42 -0
- package/ios/common/BackgroundGeolocation/FMDBLogger.m +264 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTUHeadingRequest.h +41 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTUHeadingRequest.m +68 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTULocationManager+Internal.h +33 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTULocationManager.h +178 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTULocationManager.m +1025 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTULocationRequest.h +103 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTULocationRequest.m +238 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTULocationRequestDefines.h +163 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTURequestIDGenerator.h +39 -0
- package/ios/common/BackgroundGeolocation/INTULocationManager/INTURequestIDGenerator.m +37 -0
- package/ios/common/BackgroundGeolocation/MAURAbstractLocationProvider.h +51 -0
- package/ios/common/BackgroundGeolocation/MAURAbstractLocationProvider.m +53 -0
- package/ios/common/BackgroundGeolocation/MAURActivity.h +23 -0
- package/ios/common/BackgroundGeolocation/MAURActivity.m +52 -0
- package/ios/common/BackgroundGeolocation/MAURActivityLocationProvider.h +18 -0
- package/ios/common/BackgroundGeolocation/MAURActivityLocationProvider.m +202 -0
- package/ios/common/BackgroundGeolocation/MAURBackgroundGeolocationFacade.h +62 -0
- package/ios/common/BackgroundGeolocation/MAURBackgroundGeolocationFacade.m +650 -0
- package/ios/common/BackgroundGeolocation/MAURBackgroundSync.h +34 -0
- package/ios/common/BackgroundGeolocation/MAURBackgroundSync.m +184 -0
- package/ios/common/BackgroundGeolocation/MAURBackgroundTaskManager.h +25 -0
- package/ios/common/BackgroundGeolocation/MAURBackgroundTaskManager.m +105 -0
- package/ios/common/BackgroundGeolocation/MAURConfig.h +74 -0
- package/ios/common/BackgroundGeolocation/MAURConfig.m +485 -0
- package/ios/common/BackgroundGeolocation/MAURConfigurationContract.h +49 -0
- package/ios/common/BackgroundGeolocation/MAURConfigurationContract.m +51 -0
- package/ios/common/BackgroundGeolocation/MAURDistanceFilterLocationProvider.h +20 -0
- package/ios/common/BackgroundGeolocation/MAURDistanceFilterLocationProvider.m +523 -0
- package/ios/common/BackgroundGeolocation/MAURGeolocationOpenHelper.h +17 -0
- package/ios/common/BackgroundGeolocation/MAURGeolocationOpenHelper.m +97 -0
- package/ios/common/BackgroundGeolocation/MAURLocation.h +59 -0
- package/ios/common/BackgroundGeolocation/MAURLocation.m +349 -0
- package/ios/common/BackgroundGeolocation/MAURLocationContract.h +34 -0
- package/ios/common/BackgroundGeolocation/MAURLocationContract.m +35 -0
- package/ios/common/BackgroundGeolocation/MAURLocationManager.h +53 -0
- package/ios/common/BackgroundGeolocation/MAURLocationManager.m +308 -0
- package/ios/common/BackgroundGeolocation/MAURLogReader.h +26 -0
- package/ios/common/BackgroundGeolocation/MAURLogReader.m +122 -0
- package/ios/common/BackgroundGeolocation/MAURLogging.h +19 -0
- package/ios/common/BackgroundGeolocation/MAURPostLocationTask.h +40 -0
- package/ios/common/BackgroundGeolocation/MAURPostLocationTask.m +218 -0
- package/ios/common/BackgroundGeolocation/MAURProviderDelegate.h +52 -0
- package/ios/common/BackgroundGeolocation/MAURRawLocationProvider.h +18 -0
- package/ios/common/BackgroundGeolocation/MAURRawLocationProvider.m +129 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteConfigurationDAO.h +26 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteConfigurationDAO.m +278 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteHelper.h +57 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteHelper.m +93 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteLocationDAO.h +38 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteLocationDAO.m +380 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteOpenHelper.h +32 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteOpenHelper.m +276 -0
- package/ios/common/BackgroundGeolocation/MAURUncaughtExceptionLogger.h +20 -0
- package/ios/common/BackgroundGeolocation/MAURUncaughtExceptionLogger.m +62 -0
- package/ios/common/BackgroundGeolocation/Reachability.h +102 -0
- package/ios/common/BackgroundGeolocation/Reachability.m +474 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOLocationManager.h +80 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOLocationManager.m +147 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionActivity.h +30 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionActivity.m +42 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionDetector.h +99 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionDetector.m +327 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOStepDetector.h +44 -0
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOStepDetector.m +94 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/ext/NSString+ZIMString.h +55 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/ext/NSString+ZIMString.m +47 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/sql/ZIMSqlDataManipulationCommand.h +27 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/sql/ZIMSqlExpression.h +250 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/sql/ZIMSqlExpression.m +259 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/sql/ZIMSqlSelectStatement.h +360 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/sql/ZIMSqlSelectStatement.m +427 -0
- package/ios/common/BackgroundGeolocation/SQLQueryBuilder/sql/ZIMSqlStatement.h +37 -0
- package/lib/module/NitroBackgroundGeolocation.nitro.js +172 -0
- package/lib/module/NitroBackgroundGeolocation.nitro.js.map +1 -0
- package/lib/module/headless.js +72 -0
- package/lib/module/headless.js.map +1 -0
- package/lib/module/index.js +60 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/package.json +1 -0
- package/lib/typescript/package.json +1 -0
- package/lib/typescript/src/NitroBackgroundGeolocation.nitro.d.ts +616 -0
- package/lib/typescript/src/NitroBackgroundGeolocation.nitro.d.ts.map +1 -0
- package/lib/typescript/src/headless.d.ts +40 -0
- package/lib/typescript/src/headless.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +8 -0
- package/lib/typescript/src/index.d.ts.map +1 -0
- package/nitro.json +23 -0
- package/nitrogen/generated/android/c++/JActivity.hpp +61 -0
- package/nitrogen/generated/android/c++/JAuthorizationStatus.hpp +61 -0
- package/nitrogen/generated/android/c++/JBackgroundGeolocationError.hpp +61 -0
- package/nitrogen/generated/android/c++/JConfigureOptions.hpp +179 -0
- package/nitrogen/generated/android/c++/JFunc_void.hpp +75 -0
- package/nitrogen/generated/android/c++/JFunc_void_Activity.hpp +78 -0
- package/nitrogen/generated/android/c++/JFunc_void_AuthorizationStatus.hpp +77 -0
- package/nitrogen/generated/android/c++/JFunc_void_BackgroundGeolocationError.hpp +78 -0
- package/nitrogen/generated/android/c++/JFunc_void_Location.hpp +78 -0
- package/nitrogen/generated/android/c++/JFunc_void_StationaryLocation.hpp +78 -0
- package/nitrogen/generated/android/c++/JHybridNitroBackgroundGeolocationSpec.cpp +530 -0
- package/nitrogen/generated/android/c++/JHybridNitroBackgroundGeolocationSpec.hpp +90 -0
- package/nitrogen/generated/android/c++/JLocation.hpp +105 -0
- package/nitrogen/generated/android/c++/JLocationAccuracy.hpp +64 -0
- package/nitrogen/generated/android/c++/JLocationOptions.hpp +65 -0
- package/nitrogen/generated/android/c++/JLocationProvider.hpp +61 -0
- package/nitrogen/generated/android/c++/JLogEntry.hpp +73 -0
- package/nitrogen/generated/android/c++/JNativeLogLevel.hpp +67 -0
- package/nitrogen/generated/android/c++/JServiceStatus.hpp +66 -0
- package/nitrogen/generated/android/c++/JStationaryLocation.hpp +109 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_AnyMap.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_AnyMap.hpp +71 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Boolean.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Boolean.hpp +69 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Double.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Double.hpp +69 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_LocationAccuracy.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_LocationAccuracy.hpp +71 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_LocationProvider.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_LocationProvider.hpp +71 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Map_String__String_.cpp +33 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Map_String__String_.hpp +77 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_String.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_String.hpp +70 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Activity.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/AuthorizationStatus.kt +24 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/BackgroundGeolocationError.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/ConfigureOptions.kt +182 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Func_void.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Func_void_Activity.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Func_void_AuthorizationStatus.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Func_void_BackgroundGeolocationError.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Func_void_Location.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Func_void_StationaryLocation.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/HybridNitroBackgroundGeolocationSpec.kt +218 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Location.kt +111 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/LocationAccuracy.kt +25 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/LocationOptions.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/LocationProvider.kt +24 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/LogEntry.kt +71 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/NativeLogLevel.kt +26 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/ServiceStatus.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/StationaryLocation.kt +116 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_AnyMap.kt +63 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_Boolean.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_Double.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_LocationAccuracy.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_LocationProvider.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_Map_String__String_.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/Variant_NullType_String.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrobackgroundgeolocation/nitrobackgroundgeolocationOnLoad.kt +35 -0
- package/nitrogen/generated/android/nitrobackgroundgeolocation+autolinking.cmake +88 -0
- package/nitrogen/generated/android/nitrobackgroundgeolocation+autolinking.gradle +27 -0
- package/nitrogen/generated/android/nitrobackgroundgeolocationOnLoad.cpp +66 -0
- package/nitrogen/generated/android/nitrobackgroundgeolocationOnLoad.hpp +34 -0
- package/nitrogen/generated/ios/NitroBackgroundGeolocation+autolinking.rb +62 -0
- package/nitrogen/generated/ios/NitroBackgroundGeolocation-Swift-Cxx-Bridge.cpp +129 -0
- package/nitrogen/generated/ios/NitroBackgroundGeolocation-Swift-Cxx-Bridge.hpp +911 -0
- package/nitrogen/generated/ios/NitroBackgroundGeolocation-Swift-Cxx-Umbrella.hpp +88 -0
- package/nitrogen/generated/ios/NitroBackgroundGeolocationAutolinking.mm +33 -0
- package/nitrogen/generated/ios/NitroBackgroundGeolocationAutolinking.swift +26 -0
- package/nitrogen/generated/ios/c++/HybridNitroBackgroundGeolocationSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNitroBackgroundGeolocationSpecSwift.hpp +335 -0
- package/nitrogen/generated/ios/swift/Activity.swift +34 -0
- package/nitrogen/generated/ios/swift/AuthorizationStatus.swift +44 -0
- package/nitrogen/generated/ios/swift/BackgroundGeolocationError.swift +34 -0
- package/nitrogen/generated/ios/swift/ConfigureOptions.swift +1037 -0
- package/nitrogen/generated/ios/swift/Func_void.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_Activity.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_AuthorizationStatus.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_BackgroundGeolocationError.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_ConfigureOptions.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_Location.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_ServiceStatus.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_StationaryLocation.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__optional_StationaryLocation_.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_Location_.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_LogEntry_.swift +46 -0
- package/nitrogen/generated/ios/swift/HybridNitroBackgroundGeolocationSpec.swift +82 -0
- package/nitrogen/generated/ios/swift/HybridNitroBackgroundGeolocationSpec_cxx.swift +675 -0
- package/nitrogen/generated/ios/swift/Location.swift +89 -0
- package/nitrogen/generated/ios/swift/LocationAccuracy.swift +48 -0
- package/nitrogen/generated/ios/swift/LocationOptions.swift +78 -0
- package/nitrogen/generated/ios/swift/LocationProvider.swift +44 -0
- package/nitrogen/generated/ios/swift/LogEntry.swift +49 -0
- package/nitrogen/generated/ios/swift/NativeLogLevel.swift +52 -0
- package/nitrogen/generated/ios/swift/ServiceStatus.swift +39 -0
- package/nitrogen/generated/ios/swift/StationaryLocation.swift +94 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_AnyMap.swift +30 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_Bool.swift +30 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_Dictionary_String__String_.swift +30 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_Double.swift +30 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_LocationAccuracy.swift +30 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_LocationProvider.swift +30 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_String.swift +30 -0
- package/nitrogen/generated/shared/c++/Activity.hpp +87 -0
- package/nitrogen/generated/shared/c++/AuthorizationStatus.hpp +63 -0
- package/nitrogen/generated/shared/c++/BackgroundGeolocationError.hpp +87 -0
- package/nitrogen/generated/shared/c++/ConfigureOptions.hpp +197 -0
- package/nitrogen/generated/shared/c++/HybridNitroBackgroundGeolocationSpec.cpp +48 -0
- package/nitrogen/generated/shared/c++/HybridNitroBackgroundGeolocationSpec.hpp +121 -0
- package/nitrogen/generated/shared/c++/Location.hpp +131 -0
- package/nitrogen/generated/shared/c++/LocationAccuracy.hpp +69 -0
- package/nitrogen/generated/shared/c++/LocationOptions.hpp +91 -0
- package/nitrogen/generated/shared/c++/LocationProvider.hpp +63 -0
- package/nitrogen/generated/shared/c++/LogEntry.hpp +99 -0
- package/nitrogen/generated/shared/c++/NativeLogLevel.hpp +65 -0
- package/nitrogen/generated/shared/c++/ServiceStatus.hpp +92 -0
- package/nitrogen/generated/shared/c++/StationaryLocation.hpp +135 -0
- package/package.json +112 -0
- package/react-native.config.js +10 -0
- package/src/NitroBackgroundGeolocation.nitro.ts +656 -0
- package/src/headless.ts +91 -0
- package/src/index.tsx +100 -0
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
package com.marianhello.logging;
|
|
2
|
+
|
|
3
|
+
import android.database.Cursor;
|
|
4
|
+
import android.database.sqlite.SQLiteDatabase;
|
|
5
|
+
import android.database.sqlite.SQLiteException;
|
|
6
|
+
|
|
7
|
+
import ru.andremoniy.sqlbuilder.SqlExpression;
|
|
8
|
+
import ru.andremoniy.sqlbuilder.SqlSelectStatement;
|
|
9
|
+
|
|
10
|
+
import org.slf4j.event.Level;
|
|
11
|
+
|
|
12
|
+
import java.io.File;
|
|
13
|
+
import java.sql.SQLException;
|
|
14
|
+
import java.util.ArrayList;
|
|
15
|
+
import java.util.Collection;
|
|
16
|
+
|
|
17
|
+
import ch.qos.logback.classic.LoggerContext;
|
|
18
|
+
import ch.qos.logback.classic.db.names.ColumnName;
|
|
19
|
+
import ch.qos.logback.classic.db.names.DBNameResolver;
|
|
20
|
+
import ch.qos.logback.classic.db.names.DefaultDBNameResolver;
|
|
21
|
+
import ch.qos.logback.classic.db.names.TableName;
|
|
22
|
+
import ch.qos.logback.core.CoreConstants;
|
|
23
|
+
// CommonPathUtil was removed in logback-android 2.x; use direct path construction instead
|
|
24
|
+
|
|
25
|
+
public class DBLogReader {
|
|
26
|
+
|
|
27
|
+
public static final String DB_FILENAME = "logback.db";
|
|
28
|
+
|
|
29
|
+
private DefaultDBNameResolver mDbNameResolver;
|
|
30
|
+
private SQLiteDatabase mDatabase;
|
|
31
|
+
|
|
32
|
+
public static class QueryBuilder {
|
|
33
|
+
DBNameResolver mDbNameResolver;
|
|
34
|
+
|
|
35
|
+
public QueryBuilder() {
|
|
36
|
+
mDbNameResolver = new DefaultDBNameResolver();
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public QueryBuilder(DBNameResolver dbNameResolver) {
|
|
40
|
+
mDbNameResolver = dbNameResolver;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Generate array of levels that are same or above provided level
|
|
45
|
+
*
|
|
46
|
+
* @param level
|
|
47
|
+
* @return array of levels that are same or above level
|
|
48
|
+
*/
|
|
49
|
+
private Object[] aboveLevel(Level level) {
|
|
50
|
+
ArrayList<String> levels = new ArrayList();
|
|
51
|
+
for (Level l : Level.values()) {
|
|
52
|
+
if (level.compareTo(l) >= 0) {
|
|
53
|
+
levels.add(l.toString());
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return levels.toArray();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
public String buildStackTraceQuery(int eventId) {
|
|
60
|
+
SqlSelectStatement builder = new SqlSelectStatement();
|
|
61
|
+
builder.column(mDbNameResolver.getColumnName(ColumnName.TRACE_LINE));
|
|
62
|
+
builder.from(mDbNameResolver.getTableName(TableName.LOGGING_EVENT_EXCEPTION));
|
|
63
|
+
builder.where(mDbNameResolver.getColumnName(ColumnName.I), SqlExpression.SqlOperatorEqualTo, Integer.valueOf(eventId));
|
|
64
|
+
builder.orderBy(mDbNameResolver.getColumnName(ColumnName.I));
|
|
65
|
+
|
|
66
|
+
return builder.statement();
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
public String buildQuery(int limit, int fromLogEntryId, Level minLevel) {
|
|
70
|
+
SqlSelectStatement builder = new SqlSelectStatement();
|
|
71
|
+
builder.columns(new String[]{
|
|
72
|
+
mDbNameResolver.getColumnName(ColumnName.EVENT_ID),
|
|
73
|
+
mDbNameResolver.getColumnName(ColumnName.TIMESTMP),
|
|
74
|
+
mDbNameResolver.getColumnName(ColumnName.FORMATTED_MESSAGE),
|
|
75
|
+
mDbNameResolver.getColumnName(ColumnName.LOGGER_NAME),
|
|
76
|
+
mDbNameResolver.getColumnName(ColumnName.LEVEL_STRING),
|
|
77
|
+
});
|
|
78
|
+
builder.from(mDbNameResolver.getTableName(TableName.LOGGING_EVENT));
|
|
79
|
+
builder.where(mDbNameResolver.getColumnName(ColumnName.LEVEL_STRING), SqlExpression.SqlOperatorIn, aboveLevel(minLevel));
|
|
80
|
+
if (fromLogEntryId > 0) {
|
|
81
|
+
if (limit >= 0) {
|
|
82
|
+
builder.where(mDbNameResolver.getColumnName(ColumnName.EVENT_ID), SqlExpression.SqlOperatorLessThan, fromLogEntryId);
|
|
83
|
+
} else {
|
|
84
|
+
builder.where(mDbNameResolver.getColumnName(ColumnName.EVENT_ID), SqlExpression.SqlOperatorGreaterThan, fromLogEntryId);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
if (limit < 0) {
|
|
88
|
+
builder.orderBy(mDbNameResolver.getColumnName(ColumnName.TIMESTMP));
|
|
89
|
+
builder.orderBy(mDbNameResolver.getColumnName(ColumnName.EVENT_ID));
|
|
90
|
+
} else {
|
|
91
|
+
builder.orderBy(mDbNameResolver.getColumnName(ColumnName.TIMESTMP), true);
|
|
92
|
+
builder.orderBy(mDbNameResolver.getColumnName(ColumnName.EVENT_ID), true);
|
|
93
|
+
}
|
|
94
|
+
builder.limit(limit);
|
|
95
|
+
|
|
96
|
+
return builder.statement();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
public Collection<LogEntry> getEntries(int limit, int fromLogEntryId, Level minLevel) {
|
|
101
|
+
try {
|
|
102
|
+
return getDbEntries(limit, fromLogEntryId, minLevel);
|
|
103
|
+
} catch (SQLException e) {
|
|
104
|
+
e.printStackTrace();
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
return null;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
private SQLiteDatabase openDatabase() throws SQLException {
|
|
111
|
+
if (mDatabase != null && mDatabase.isOpen()) {
|
|
112
|
+
return mDatabase;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
String packageName = null;
|
|
116
|
+
LoggerContext context = (LoggerContext) org.slf4j.LoggerFactory.getILoggerFactory();
|
|
117
|
+
|
|
118
|
+
if (context != null) {
|
|
119
|
+
packageName = context.getProperty(CoreConstants.PACKAGE_NAME_KEY);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
if (packageName == null || packageName.length() == 0) {
|
|
123
|
+
throw new SQLException("Cannot open database without package name");
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
try {
|
|
127
|
+
File dbfile = new File("/data/data/" + packageName + "/databases", DB_FILENAME);
|
|
128
|
+
mDatabase = SQLiteDatabase.openDatabase(dbfile.getPath(), null, SQLiteDatabase.OPEN_READONLY);
|
|
129
|
+
} catch (SQLiteException e) {
|
|
130
|
+
throw new SQLException("Cannot open database", e);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
return mDatabase;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
private DefaultDBNameResolver getDbNameResolver() {
|
|
137
|
+
if (mDbNameResolver != null) {
|
|
138
|
+
return mDbNameResolver;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
mDbNameResolver = new DefaultDBNameResolver();
|
|
142
|
+
return mDbNameResolver;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
private Collection<String> getStackTrace(int logEntryId) throws SQLException {
|
|
146
|
+
Collection<String> stackTrace = new ArrayList();
|
|
147
|
+
SQLiteDatabase db = openDatabase();
|
|
148
|
+
Cursor cursor = null;
|
|
149
|
+
|
|
150
|
+
try {
|
|
151
|
+
DefaultDBNameResolver dbNameResolver = getDbNameResolver();
|
|
152
|
+
QueryBuilder qb = new QueryBuilder(dbNameResolver);
|
|
153
|
+
cursor = mDatabase.rawQuery(qb.buildStackTraceQuery(logEntryId), new String[] {});
|
|
154
|
+
while (cursor.moveToNext()) {
|
|
155
|
+
stackTrace.add(cursor.getString(cursor.getColumnIndex(dbNameResolver.getColumnName(ColumnName.TRACE_LINE))));
|
|
156
|
+
}
|
|
157
|
+
} catch (SQLiteException e) {
|
|
158
|
+
throw new SQLException("Cannot retrieve log entries", e);
|
|
159
|
+
} finally {
|
|
160
|
+
if (cursor != null) {
|
|
161
|
+
cursor.close();
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
return stackTrace;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
private Collection<LogEntry> getDbEntries(int limit, int fromLogEntryId, Level minLevel) throws SQLException {
|
|
169
|
+
Collection<LogEntry> entries = new ArrayList<LogEntry>();
|
|
170
|
+
SQLiteDatabase db = openDatabase();
|
|
171
|
+
Cursor cursor = null;
|
|
172
|
+
|
|
173
|
+
try {
|
|
174
|
+
DefaultDBNameResolver dbNameResolver = getDbNameResolver();
|
|
175
|
+
QueryBuilder qb = new QueryBuilder(dbNameResolver);
|
|
176
|
+
cursor = db.rawQuery(qb.buildQuery(limit, fromLogEntryId, minLevel), new String[] {});
|
|
177
|
+
while (cursor.moveToNext()) {
|
|
178
|
+
LogEntry entry = new LogEntry();
|
|
179
|
+
entry.setContext(0);
|
|
180
|
+
entry.setId(cursor.getInt(cursor.getColumnIndex(mDbNameResolver.getColumnName(ColumnName.EVENT_ID))));
|
|
181
|
+
entry.setLevel(cursor.getString(cursor.getColumnIndex(dbNameResolver.getColumnName(ColumnName.LEVEL_STRING))));
|
|
182
|
+
entry.setMessage(cursor.getString(cursor.getColumnIndex(dbNameResolver.getColumnName(ColumnName.FORMATTED_MESSAGE))));
|
|
183
|
+
entry.setTimestamp(cursor.getLong(cursor.getColumnIndex(dbNameResolver.getColumnName(ColumnName.TIMESTMP))));
|
|
184
|
+
entry.setLoggerName(cursor.getString(cursor.getColumnIndex(dbNameResolver.getColumnName(ColumnName.LOGGER_NAME))));
|
|
185
|
+
if ("ERROR".equals(entry.getLevel())) {
|
|
186
|
+
entry.setStackTrace(getStackTrace(entry.getId()));
|
|
187
|
+
}
|
|
188
|
+
entries.add(entry);
|
|
189
|
+
}
|
|
190
|
+
} catch (SQLiteException e) {
|
|
191
|
+
throw new SQLException("Cannot retrieve log entries", e);
|
|
192
|
+
} finally {
|
|
193
|
+
if (cursor != null) {
|
|
194
|
+
cursor.close();
|
|
195
|
+
}
|
|
196
|
+
if (db != null) {
|
|
197
|
+
db.close();
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
return entries;
|
|
202
|
+
}
|
|
203
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
package com.marianhello.logging;
|
|
2
|
+
|
|
3
|
+
import org.json.JSONException;
|
|
4
|
+
import org.json.JSONObject;
|
|
5
|
+
|
|
6
|
+
import java.util.Collection;
|
|
7
|
+
|
|
8
|
+
public class LogEntry {
|
|
9
|
+
private Integer id;
|
|
10
|
+
private Integer context;
|
|
11
|
+
private String level;
|
|
12
|
+
private String message;
|
|
13
|
+
private Long timestamp;
|
|
14
|
+
private String loggerName;
|
|
15
|
+
private Collection<String> stackTrace;
|
|
16
|
+
|
|
17
|
+
public Integer getId() {
|
|
18
|
+
return id;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public void setId(Integer id) {
|
|
22
|
+
this.id = id;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
public Integer getContext() {
|
|
26
|
+
return context;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
public void setContext(Integer context) {
|
|
30
|
+
this.context = context;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public String getLevel() {
|
|
34
|
+
return level;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
public void setLevel(String level) {
|
|
38
|
+
this.level = level;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
public String getMessage() {
|
|
42
|
+
return message;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
public void setMessage(String message) {
|
|
46
|
+
this.message = message;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
public Long getTimestamp() {
|
|
50
|
+
return timestamp;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
public void setTimestamp(Long timestamp) {
|
|
54
|
+
this.timestamp = timestamp;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public String getLoggerName() {
|
|
58
|
+
return loggerName;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
public void setLoggerName(String loggerName) {
|
|
62
|
+
this.loggerName = loggerName;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
public boolean hasStackTrace() {
|
|
66
|
+
return stackTrace != null;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
public String getStackTrace() {
|
|
70
|
+
if (this.stackTrace == null) {
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
StringBuilder stackTraceBuilder = new StringBuilder();
|
|
75
|
+
for (String traceLine : this.stackTrace) {
|
|
76
|
+
stackTraceBuilder.append(traceLine).append("\n");
|
|
77
|
+
}
|
|
78
|
+
return stackTraceBuilder.toString();
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
public void setStackTrace(Collection<String> stackTrace) {
|
|
82
|
+
this.stackTrace = stackTrace;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
public JSONObject toJSONObject() throws JSONException {
|
|
86
|
+
JSONObject json = new JSONObject();
|
|
87
|
+
json.put("id", this.id);
|
|
88
|
+
json.put("context", this.context);
|
|
89
|
+
json.put("level", this.level);
|
|
90
|
+
json.put("message", this.message);
|
|
91
|
+
json.put("timestamp", this.timestamp);
|
|
92
|
+
json.put("logger", this.loggerName);
|
|
93
|
+
if (hasStackTrace()) {
|
|
94
|
+
json.put("stackTrace", this.getStackTrace());
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
return json;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
package com.marianhello.logging;
|
|
2
|
+
|
|
3
|
+
import java.io.File;
|
|
4
|
+
|
|
5
|
+
import ch.qos.logback.classic.Level;
|
|
6
|
+
import ch.qos.logback.classic.Logger;
|
|
7
|
+
import ch.qos.logback.classic.LoggerContext;
|
|
8
|
+
import ch.qos.logback.classic.android.LogcatAppender;
|
|
9
|
+
import ch.qos.logback.classic.android.SQLiteAppender;
|
|
10
|
+
import ch.qos.logback.classic.encoder.PatternLayoutEncoder;
|
|
11
|
+
import ch.qos.logback.classic.spi.ILoggingEvent;
|
|
12
|
+
import ch.qos.logback.core.Appender;
|
|
13
|
+
import ch.qos.logback.core.rolling.RollingFileAppender;
|
|
14
|
+
import ch.qos.logback.core.rolling.TimeBasedRollingPolicy;
|
|
15
|
+
import ch.qos.logback.core.util.StatusPrinter;
|
|
16
|
+
|
|
17
|
+
public class LoggerManager {
|
|
18
|
+
|
|
19
|
+
public static final String SQLITE_APPENDER_NAME = "sqlite";
|
|
20
|
+
|
|
21
|
+
static {
|
|
22
|
+
// reset the default context (which may already have been initialized)
|
|
23
|
+
// since we want to reconfigure it
|
|
24
|
+
LoggerContext context = (LoggerContext) org.slf4j.LoggerFactory.getILoggerFactory();
|
|
25
|
+
context.reset();
|
|
26
|
+
// Disable class packaging data
|
|
27
|
+
// @see https://github.com/tony19/logback-android/issues/171
|
|
28
|
+
context.setPackagingDataEnabled(false);
|
|
29
|
+
|
|
30
|
+
PatternLayoutEncoder encoder = new PatternLayoutEncoder();
|
|
31
|
+
encoder.setContext(context);
|
|
32
|
+
encoder.setPattern("%msg");
|
|
33
|
+
encoder.start();
|
|
34
|
+
|
|
35
|
+
LogcatAppender logcatAppender = new LogcatAppender();
|
|
36
|
+
logcatAppender.setContext(context);
|
|
37
|
+
logcatAppender.setEncoder(encoder);
|
|
38
|
+
logcatAppender.start();
|
|
39
|
+
|
|
40
|
+
ch.qos.logback.classic.Logger root = (ch.qos.logback.classic.Logger) org.slf4j.LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
|
|
41
|
+
root.setLevel(Level.TRACE);
|
|
42
|
+
root.addAppender(logcatAppender);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
public static void enableDBLogging() {
|
|
46
|
+
ch.qos.logback.classic.Logger root = (ch.qos.logback.classic.Logger) org.slf4j.LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
|
|
47
|
+
if (root.getAppender(SQLITE_APPENDER_NAME) == null) {
|
|
48
|
+
LoggerContext context = (LoggerContext) org.slf4j.LoggerFactory.getILoggerFactory();
|
|
49
|
+
SQLiteAppender appender = new SQLiteAppender();
|
|
50
|
+
appender.setName(SQLITE_APPENDER_NAME);
|
|
51
|
+
appender.setMaxHistory("7 days"); //keep 7 days' worth of history
|
|
52
|
+
appender.setContext(context);
|
|
53
|
+
appender.start();
|
|
54
|
+
root.addAppender(appender);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
public static void disableDBLogging() {
|
|
59
|
+
ch.qos.logback.classic.Logger root = (ch.qos.logback.classic.Logger) org.slf4j.LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
|
|
60
|
+
Appender<ILoggingEvent> appender = root.getAppender(SQLITE_APPENDER_NAME);
|
|
61
|
+
if (appender != null) {
|
|
62
|
+
appender.stop();
|
|
63
|
+
root.detachAppender(appender);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
public static org.slf4j.Logger getLogger(Class forClass) {
|
|
68
|
+
return org.slf4j.LoggerFactory.getLogger(forClass);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
package com.marianhello.logging;
|
|
2
|
+
|
|
3
|
+
import android.content.Context;
|
|
4
|
+
|
|
5
|
+
public class UncaughtExceptionLogger implements Thread.UncaughtExceptionHandler {
|
|
6
|
+
private static volatile boolean mIsCrashing = false;
|
|
7
|
+
private static Thread.UncaughtExceptionHandler sDefaultHandler;
|
|
8
|
+
|
|
9
|
+
private org.slf4j.Logger logger;
|
|
10
|
+
|
|
11
|
+
public UncaughtExceptionLogger(Context context) {
|
|
12
|
+
logger = LoggerManager.getLogger(UncaughtExceptionLogger.class);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
@Override
|
|
16
|
+
public void uncaughtException(Thread thread, Throwable throwable) {
|
|
17
|
+
// prevent accidental loop
|
|
18
|
+
if(mIsCrashing){
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
mIsCrashing = true;
|
|
23
|
+
logger.error("FATAL EXCEPTION: {}", thread.getName(), throwable);
|
|
24
|
+
if (sDefaultHandler != null) {
|
|
25
|
+
sDefaultHandler.uncaughtException(thread, throwable);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
public static void register(Context context) {
|
|
30
|
+
Thread.UncaughtExceptionHandler defaultHandler = Thread.getDefaultUncaughtExceptionHandler();
|
|
31
|
+
if (!(defaultHandler instanceof UncaughtExceptionLogger)) {
|
|
32
|
+
sDefaultHandler = defaultHandler;
|
|
33
|
+
Thread.setDefaultUncaughtExceptionHandler(new UncaughtExceptionLogger(context));
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
package com.marianhello.utils;
|
|
2
|
+
|
|
3
|
+
import java.util.HashMap;
|
|
4
|
+
import java.util.Map;
|
|
5
|
+
|
|
6
|
+
public class CloneHelper {
|
|
7
|
+
public static <K,V> HashMap<K, V> deepCopy(HashMap<K, V> original)
|
|
8
|
+
{
|
|
9
|
+
if (original == null) {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
HashMap<K, V> copy = new HashMap();
|
|
14
|
+
|
|
15
|
+
//iterate over the map copying values into new map
|
|
16
|
+
for(Map.Entry<K, V> entry : original.entrySet()) {
|
|
17
|
+
copy.put(entry.getKey(), entry.getValue());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
return copy;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Kindly taken from
|
|
3
|
+
* http://stackoverflow.com/questions/1590831/safely-casting-long-to-int-in-java
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
package com.marianhello.utils;
|
|
7
|
+
|
|
8
|
+
import org.json.JSONArray;
|
|
9
|
+
import org.json.JSONException;
|
|
10
|
+
import org.json.JSONObject;
|
|
11
|
+
|
|
12
|
+
import java.util.ArrayList;
|
|
13
|
+
import java.util.HashMap;
|
|
14
|
+
import java.util.Iterator;
|
|
15
|
+
import java.util.List;
|
|
16
|
+
import java.util.Map;
|
|
17
|
+
|
|
18
|
+
public class Convert {
|
|
19
|
+
|
|
20
|
+
public static int safeLongToInt(long l) {
|
|
21
|
+
if (l < Integer.MIN_VALUE || l > Integer.MAX_VALUE) {
|
|
22
|
+
throw new IllegalArgumentException
|
|
23
|
+
(l + " cannot be cast to int without changing its value.");
|
|
24
|
+
}
|
|
25
|
+
return (int) l;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
public static Map<String, Object> toMap(JSONObject jsonobj) throws JSONException {
|
|
29
|
+
Map<String, Object> map = new HashMap<String, Object>();
|
|
30
|
+
Iterator<String> keys = jsonobj.keys();
|
|
31
|
+
while(keys.hasNext()) {
|
|
32
|
+
String key = keys.next();
|
|
33
|
+
Object value = jsonobj.get(key);
|
|
34
|
+
if (value instanceof JSONArray) {
|
|
35
|
+
value = toList((JSONArray) value);
|
|
36
|
+
} else if (value instanceof JSONObject) {
|
|
37
|
+
value = toMap((JSONObject) value);
|
|
38
|
+
}
|
|
39
|
+
map.put(key, value);
|
|
40
|
+
} return map;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public static List<Object> toList(JSONArray array) throws JSONException {
|
|
44
|
+
List<Object> list = new ArrayList<Object>();
|
|
45
|
+
for(int i = 0; i < array.length(); i++) {
|
|
46
|
+
Object value = array.get(i);
|
|
47
|
+
if (value instanceof JSONArray) {
|
|
48
|
+
value = toList((JSONArray) value);
|
|
49
|
+
}
|
|
50
|
+
else if (value instanceof JSONObject) {
|
|
51
|
+
value = toMap((JSONObject) value);
|
|
52
|
+
}
|
|
53
|
+
list.add(value);
|
|
54
|
+
} return list;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (C) 2006 The Android Open Source Project
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
package com.marianhello.utils;
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
import java.util.Iterator;
|
|
21
|
+
|
|
22
|
+
public class TextUtils {
|
|
23
|
+
private static final String TAG = "TextUtils";
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Returns a string containing the tokens joined by delimiters.
|
|
27
|
+
* @param tokens an array objects to be joined. Strings will be formed from
|
|
28
|
+
* the objects by calling object.toString().
|
|
29
|
+
*/
|
|
30
|
+
public static String join(CharSequence delimiter, Object[] tokens) {
|
|
31
|
+
StringBuilder sb = new StringBuilder();
|
|
32
|
+
boolean firstTime = true;
|
|
33
|
+
for (Object token: tokens) {
|
|
34
|
+
if (firstTime) {
|
|
35
|
+
firstTime = false;
|
|
36
|
+
} else {
|
|
37
|
+
sb.append(delimiter);
|
|
38
|
+
}
|
|
39
|
+
sb.append(token);
|
|
40
|
+
}
|
|
41
|
+
return sb.toString();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Returns a string containing the tokens joined by delimiters.
|
|
46
|
+
* @param tokens an array objects to be joined. Strings will be formed from
|
|
47
|
+
* the objects by calling object.toString().
|
|
48
|
+
*/
|
|
49
|
+
public static String join(CharSequence delimiter, Iterable tokens) {
|
|
50
|
+
StringBuilder sb = new StringBuilder();
|
|
51
|
+
Iterator<?> it = tokens.iterator();
|
|
52
|
+
if (it.hasNext()) {
|
|
53
|
+
sb.append(it.next());
|
|
54
|
+
while (it.hasNext()) {
|
|
55
|
+
sb.append(delimiter);
|
|
56
|
+
sb.append(it.next());
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return sb.toString();
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
public static String removeLastChar(String str, String lastChar) {
|
|
63
|
+
if (str == null) {
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
int indexOfLastChar = str.length() - 1;
|
|
67
|
+
if (lastChar == null || str.substring(indexOfLastChar).equals(lastChar)) {
|
|
68
|
+
return str.substring(0, indexOfLastChar);
|
|
69
|
+
}
|
|
70
|
+
return str;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
package com.marianhello.utils;
|
|
2
|
+
|
|
3
|
+
import com.marianhello.logging.LoggerManager;
|
|
4
|
+
|
|
5
|
+
import java.util.concurrent.Executors;
|
|
6
|
+
import java.util.concurrent.ScheduledExecutorService;
|
|
7
|
+
import java.util.concurrent.TimeUnit;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Created by finch on 27.11.2017.
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
public class ToneGenerator {
|
|
14
|
+
public class Tone {
|
|
15
|
+
public static final int BEEP = android.media.ToneGenerator.TONE_PROP_BEEP;
|
|
16
|
+
public static final int BEEP_BEEP_BEEP = android.media.ToneGenerator.TONE_CDMA_CONFIRM;
|
|
17
|
+
public static final int LONG_BEEP = android.media.ToneGenerator.TONE_CDMA_ABBR_ALERT;
|
|
18
|
+
public static final int DOODLY_DOO = android.media.ToneGenerator.TONE_CDMA_ALERT_NETWORK_LITE;
|
|
19
|
+
public static final int CHIRP_CHIRP_CHIRP = android.media.ToneGenerator.TONE_CDMA_ALERT_CALL_GUARD;
|
|
20
|
+
public static final int DIALTONE = android.media.ToneGenerator.TONE_SUP_RINGTONE;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
private int mStreamType;
|
|
24
|
+
private int mVolume;
|
|
25
|
+
private final ScheduledExecutorService mExecutor;
|
|
26
|
+
private org.slf4j.Logger logger;
|
|
27
|
+
|
|
28
|
+
public ToneGenerator(int streamType, int volume) {
|
|
29
|
+
mStreamType = streamType;
|
|
30
|
+
mVolume = volume;
|
|
31
|
+
mExecutor = Executors.newScheduledThreadPool(1);
|
|
32
|
+
logger = LoggerManager.getLogger(getClass());
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
public void release() {
|
|
36
|
+
mExecutor.shutdown();
|
|
37
|
+
try {
|
|
38
|
+
if (!mExecutor.awaitTermination(1, TimeUnit.SECONDS)) {
|
|
39
|
+
mExecutor.shutdownNow();
|
|
40
|
+
}
|
|
41
|
+
} catch (InterruptedException e) {
|
|
42
|
+
mExecutor.shutdownNow();
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
public void startTone(final int toneType, final int durationMs) {
|
|
47
|
+
final android.media.ToneGenerator toneGenerator = new android.media.ToneGenerator(mStreamType, mVolume);
|
|
48
|
+
mExecutor.execute(new Runnable() {
|
|
49
|
+
@Override
|
|
50
|
+
public void run() {
|
|
51
|
+
try {
|
|
52
|
+
toneGenerator.startTone(toneType, durationMs);
|
|
53
|
+
} catch (Exception e) {
|
|
54
|
+
logger.debug("Exception while playing tone: {}", e.getMessage());
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
mExecutor.schedule(new Runnable() {
|
|
59
|
+
public void run() {
|
|
60
|
+
try {
|
|
61
|
+
toneGenerator.release();
|
|
62
|
+
} catch (Exception e) {
|
|
63
|
+
logger.debug("Exception while playing tone: {}", e.getMessage());
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}, durationMs, TimeUnit.MILLISECONDS);
|
|
67
|
+
}
|
|
68
|
+
}
|