@josuelmm/cordova-background-geolocation 4.2.3 → 4.5.2
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/.npmignore +11 -0
- package/CHANGELOG.md +261 -0
- package/README.md +306 -115
- package/android/CDVBackgroundGeolocation/src/main/java/com/marianhello/bgloc/cordova/ConfigMapper.java +34 -0
- package/android/CDVBackgroundGeolocation/src/main/java/com/tenforwardconsulting/bgloc/cordova/BackgroundGeolocationPlugin.java +61 -1
- package/android/common/src/main/AndroidManifest.xml +1 -1
- package/android/common/src/main/java/com/marianhello/bgloc/BootCompletedReceiver.java +20 -3
- package/android/common/src/main/java/com/marianhello/bgloc/Config.java +87 -1
- package/android/common/src/main/java/com/marianhello/bgloc/data/BackgroundLocation.java +94 -0
- package/android/common/src/main/java/com/marianhello/bgloc/data/ConfigJsonMapper.java +211 -0
- package/android/common/src/main/java/com/marianhello/bgloc/data/LocationTemplateFactory.java +6 -0
- package/android/common/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteConfigurationContract.java +5 -1
- package/android/common/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteConfigurationDAO.java +32 -1
- package/android/common/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteLocationContract.java +12 -2
- package/android/common/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteLocationDAO.java +33 -2
- package/android/common/src/main/java/com/marianhello/bgloc/data/sqlite/SQLiteOpenHelper.java +15 -1
- package/android/common/src/main/java/com/marianhello/bgloc/provider/AbstractLocationProvider.java +48 -1
- package/android/common/src/main/java/com/marianhello/bgloc/provider/ActivityRecognitionLocationProvider.java +105 -6
- package/android/common/src/main/java/com/marianhello/bgloc/provider/DistanceFilterLocationProvider.java +336 -250
- package/android/common/src/main/java/com/marianhello/bgloc/provider/RawLocationProvider.java +69 -19
- package/android/common/src/main/java/com/marianhello/bgloc/service/LocationServiceImpl.java +246 -21
- package/android/common/src/main/java/com/marianhello/bgloc/service/LocationServiceProxy.java +5 -2
- package/android/common/src/main/java/com/marianhello/bgloc/sync/BatchManager.java +46 -13
- package/ios/CDVBackgroundGeolocation/CDVBackgroundGeolocation.m +23 -1
- package/ios/common/BackgroundGeolocation/MAURActivityLocationProvider.m +208 -70
- package/ios/common/BackgroundGeolocation/MAURBackgroundGeolocationFacade.m +132 -5
- package/ios/common/BackgroundGeolocation/MAURBackgroundSync.m +20 -0
- package/ios/common/BackgroundGeolocation/MAURConfig.h +7 -0
- package/ios/common/BackgroundGeolocation/MAURConfig.m +37 -2
- package/ios/common/BackgroundGeolocation/MAURConfigurationContract.h +3 -0
- package/ios/common/BackgroundGeolocation/MAURConfigurationContract.m +3 -1
- package/ios/common/BackgroundGeolocation/MAURDistanceFilterLocationProvider.m +10 -1
- package/ios/common/BackgroundGeolocation/MAURGeolocationOpenHelper.m +15 -1
- package/ios/common/BackgroundGeolocation/MAURLocation.h +12 -0
- package/ios/common/BackgroundGeolocation/MAURLocation.m +33 -4
- package/ios/common/BackgroundGeolocation/MAURLocationContract.h +4 -0
- package/ios/common/BackgroundGeolocation/MAURLocationContract.m +5 -1
- package/ios/common/BackgroundGeolocation/MAURLocationManager.m +19 -1
- package/ios/common/BackgroundGeolocation/MAURPostLocationTask.h +9 -0
- package/ios/common/BackgroundGeolocation/MAURPostLocationTask.m +59 -1
- package/ios/common/BackgroundGeolocation/MAURRawLocationProvider.m +10 -1
- package/ios/common/BackgroundGeolocation/MAURSQLiteConfigurationDAO.m +54 -4
- package/ios/common/BackgroundGeolocation/MAURSQLiteLocationDAO.h +12 -0
- package/ios/common/BackgroundGeolocation/MAURSQLiteLocationDAO.m +125 -5
- package/package.json +31 -1
- package/plugin.xml +3 -10
- package/www/BackgroundGeolocation.d.ts +143 -3
- package/www/BackgroundGeolocation.js +11 -4
- package/CLAUDE.md +0 -56
- package/HISTORY.md +0 -871
- package/android/CDVBackgroundGeolocation/src/test/java/com/marianhello/ConfigMapperTest.java +0 -220
- package/android/common/src/androidTest/java/com/marianhello/bgloc/BackgroundGeolocationFacadeTest.java +0 -45
- package/android/common/src/androidTest/java/com/marianhello/bgloc/BatchManagerTest.java +0 -570
- package/android/common/src/androidTest/java/com/marianhello/bgloc/ConfigTest.java +0 -76
- package/android/common/src/androidTest/java/com/marianhello/bgloc/ContentProviderLocationDAOTest.java +0 -437
- package/android/common/src/androidTest/java/com/marianhello/bgloc/DBLogReaderTest.java +0 -95
- package/android/common/src/androidTest/java/com/marianhello/bgloc/LocationContentProviderTest.java +0 -159
- package/android/common/src/androidTest/java/com/marianhello/bgloc/LocationServiceProxyTest.java +0 -161
- package/android/common/src/androidTest/java/com/marianhello/bgloc/LocationServiceTest.java +0 -247
- package/android/common/src/androidTest/java/com/marianhello/bgloc/SQLiteConfigurationDAOTest.java +0 -200
- package/android/common/src/androidTest/java/com/marianhello/bgloc/SQLiteLocationDAOTest.java +0 -457
- package/android/common/src/androidTest/java/com/marianhello/bgloc/SQLiteLocationDAOThreadTest.java +0 -96
- package/android/common/src/androidTest/java/com/marianhello/bgloc/SQLiteOpenHelperTest.java +0 -225
- package/android/common/src/androidTest/java/com/marianhello/bgloc/TestPluginDelegate.java +0 -46
- package/android/common/src/androidTest/java/com/marianhello/bgloc/TestResourceResolver.java +0 -14
- package/android/common/src/androidTest/java/com/marianhello/bgloc/provider/MockLocationProvider.java +0 -50
- package/android/common/src/androidTest/java/com/marianhello/bgloc/provider/TestLocationProviderFactory.java +0 -17
- package/android/common/src/androidTest/java/com/marianhello/bgloc/sqlite/SQLiteOpenHelper10.java +0 -92
- package/android/common/src/androidTest/java/com/marianhello/bgloc/test/LocationProviderTestCase.java +0 -107
- package/android/common/src/androidTest/java/com/marianhello/bgloc/test/TestConstants.java +0 -5
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/ArrayListLocationTemplateTest.java +0 -82
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/BackgroundLocationTest.java +0 -128
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/ConfigTest.java +0 -191
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/DBLogReaderTest.java +0 -37
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/HashMapLocationTemplateTest.java +0 -216
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/HttpPostServiceTest.java +0 -223
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/LocationTemplateFactoryTest.java +0 -50
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/PostLocationTaskTest.java +0 -180
- package/android/common/src/test/java/com/marianhello/backgroundgeolocation/TestHelper.java +0 -16
- package/ios/common/BackgroundGeolocation/SOMotionDetector/CHANGELOG.md +0 -2
- package/ios/common/BackgroundGeolocation/SOMotionDetector/LICENSE +0 -21
- package/ios/common/BackgroundGeolocation/SOMotionDetector/README.md +0 -135
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOLocationManager.h +0 -80
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOLocationManager.m +0 -147
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionActivity.h +0 -30
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionActivity.m +0 -42
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionDetector.h +0 -99
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOMotionDetector.m +0 -327
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOStepDetector.h +0 -44
- package/ios/common/BackgroundGeolocation/SOMotionDetector/SOStepDetector.m +0 -94
- package/ios/common/BackgroundGeolocationTests/Info.plist +0 -24
- package/ios/common/BackgroundGeolocationTests/MAURBackgroundLocationTest.m +0 -185
- package/ios/common/BackgroundGeolocationTests/MAURConfigTest.m +0 -161
- package/ios/common/BackgroundGeolocationTests/MAURGeolocationOpenHelperTest.m +0 -102
- package/ios/common/BackgroundGeolocationTests/MAURLocationTest.m +0 -216
- package/ios/common/BackgroundGeolocationTests/MAURLocationUploaderTest.m +0 -55
- package/ios/common/BackgroundGeolocationTests/MAURLogReaderTest.m +0 -43
- package/ios/common/BackgroundGeolocationTests/MAURSQLiteConfigurationDAOTest.m +0 -102
- package/ios/common/BackgroundGeolocationTests/MAURSQLiteHelperTest.m +0 -41
- package/ios/common/BackgroundGeolocationTests/MAURSQLiteLocationDAOTests.m +0 -240
- package/ios/common/BackgroundGeolocationTests/MAURSQLiteLocationDAOThreadTest.m +0 -84
- package/ios/common/BackgroundGeolocationTests/MAURSQLiteOpenHelperTest.m +0 -144
- package/ios/common/scripts/xcode-refactor.js +0 -184
|
@@ -1,184 +0,0 @@
|
|
|
1
|
-
const fs = require('fs');
|
|
2
|
-
const path = require('path');
|
|
3
|
-
|
|
4
|
-
const DIRECTORIES = ['BackgroundGeolocation', 'BackgroundGeolocationTests'];
|
|
5
|
-
const PBX_PROJ = path.join('BackgroundGeolocation.xcodeproj', 'project.pbxproj');
|
|
6
|
-
const PREFIX = 'MAUR';
|
|
7
|
-
const FILENAME_INCLUDE_CRITERIA = [
|
|
8
|
-
/\.h$/,
|
|
9
|
-
/\.m$/,
|
|
10
|
-
];
|
|
11
|
-
const FILENAME_EXCLUDE_CRITERIA = [
|
|
12
|
-
RegExp(`^${PREFIX}`), // file is already prefixed
|
|
13
|
-
/^(?=[A-Z]{2,})((?!SQL)).*/, //match leading 2 capital letters except SQL
|
|
14
|
-
/^Reachability/,
|
|
15
|
-
/^CocoaLumberjack/,
|
|
16
|
-
/^Util/
|
|
17
|
-
];
|
|
18
|
-
const IMPORT_REGEXP = /\s*#import\s?\"(\w+\.[a-z]?)\"/g;
|
|
19
|
-
|
|
20
|
-
// https://stackoverflow.com/a/6969486/3896616
|
|
21
|
-
function escapeRegExp(str) {
|
|
22
|
-
return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
let files = [].concat.apply([], DIRECTORIES.map(dir => fs.readdirSync(dir)
|
|
26
|
-
.filter(fileName => {
|
|
27
|
-
if (!FILENAME_INCLUDE_CRITERIA.some(regexp => regexp.test(fileName))) {
|
|
28
|
-
return false;
|
|
29
|
-
}
|
|
30
|
-
if (!FILENAME_EXCLUDE_CRITERIA.some(regexp => regexp.test(fileName))) {
|
|
31
|
-
return true;
|
|
32
|
-
}
|
|
33
|
-
return false;
|
|
34
|
-
})
|
|
35
|
-
.map(fileName => [dir, fileName])
|
|
36
|
-
));
|
|
37
|
-
|
|
38
|
-
const refactorTable = files.reduce((memo, [dir, fileName]) => {
|
|
39
|
-
memo[fileName] = `${PREFIX}${fileName}`;
|
|
40
|
-
return memo;
|
|
41
|
-
}, {});
|
|
42
|
-
|
|
43
|
-
const objInstances = Object.entries(refactorTable).reduce((memo, [fileName, newFileName]) => {
|
|
44
|
-
const [instanceName] = fileName.split('.');
|
|
45
|
-
const [newInstanceName] = newFileName.split('.');
|
|
46
|
-
memo[instanceName] = newInstanceName;
|
|
47
|
-
return memo;
|
|
48
|
-
}, {});
|
|
49
|
-
|
|
50
|
-
const ref = files.map(([dir, fileName]) => {
|
|
51
|
-
let matches;
|
|
52
|
-
const imports = [];
|
|
53
|
-
const [file, extension = ''] = fileName.split('.');
|
|
54
|
-
const fileComment = extension ? `${file}_${extension}` : file;
|
|
55
|
-
const oldPath = path.join(dir, fileName);
|
|
56
|
-
const newPath = path.join(dir, refactorTable[fileName]);
|
|
57
|
-
let content = fs.readFileSync(oldPath, 'utf8');
|
|
58
|
-
|
|
59
|
-
// log imports to be returned from function
|
|
60
|
-
while ((matches = IMPORT_REGEXP.exec(content)) !== null) {
|
|
61
|
-
const [match, p1] = matches;
|
|
62
|
-
imports.push(p1);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// replace imports
|
|
66
|
-
content = content.replace(IMPORT_REGEXP, (match, fileName) => {
|
|
67
|
-
const beginIndex = match.indexOf(fileName);
|
|
68
|
-
const begin = match.substring(0, beginIndex);
|
|
69
|
-
const end = match.substring(beginIndex + fileName.length);
|
|
70
|
-
const refactoredFileName = refactorTable[fileName] || fileName;
|
|
71
|
-
return `${begin}${refactoredFileName}${end}`;
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
/*
|
|
75
|
-
replace class name in comment
|
|
76
|
-
eg:
|
|
77
|
-
// BackgroundGeolocationFacade.h
|
|
78
|
-
*/
|
|
79
|
-
content = content.replace(RegExp(`\/\/\\s*(${escapeRegExp(fileName)})`), (match, p1) => {
|
|
80
|
-
const beginIndex = match.indexOf(p1);
|
|
81
|
-
const begin = match.substring(0, beginIndex);
|
|
82
|
-
const end = match.substring(beginIndex + p1.length);
|
|
83
|
-
return `${begin}${PREFIX}${p1}${end}`;
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
// replace ifdefs and ifndef
|
|
87
|
-
content = content.replace(RegExp(`#ifndef\\s*(${escapeRegExp(fileComment)})`), (match, p1) => {
|
|
88
|
-
const beginIndex = match.indexOf(p1);
|
|
89
|
-
const begin = match.substring(0, beginIndex);
|
|
90
|
-
const end = match.substring(beginIndex + p1.length);
|
|
91
|
-
return `${begin}${PREFIX}${p1}${end}`;
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
// replace define
|
|
95
|
-
content = content.replace(RegExp(`#define\\s*(${escapeRegExp(fileComment)})`), (match, p1) => {
|
|
96
|
-
const beginIndex = match.indexOf(p1);
|
|
97
|
-
const begin = match.substring(0, beginIndex);
|
|
98
|
-
const end = match.substring(beginIndex + p1.length);
|
|
99
|
-
return `${begin}${PREFIX}${p1}${end}`;
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
// replace endif
|
|
103
|
-
content = content.replace(RegExp(`#endif\\s*\\/\\*\\s*(${escapeRegExp(fileComment)})\\s*\\*\\/`), (match, p1) => {
|
|
104
|
-
const beginIndex = match.indexOf(p1);
|
|
105
|
-
const begin = match.substring(0, beginIndex);
|
|
106
|
-
const end = match.substring(beginIndex + p1.length);
|
|
107
|
-
return `${begin}${PREFIX}${p1}${end}`;
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
// replace interface
|
|
111
|
-
content = content.replace(RegExp(`\\s*@interface\\s*(${escapeRegExp(file)})\\s*(:\\s*(\\w+)(<\\w+>)?)?`), (match, p1, p2, p3) => {
|
|
112
|
-
if (p3) {
|
|
113
|
-
const beginIndex = match.indexOf(p1);
|
|
114
|
-
const begin = match.substring(0, beginIndex);
|
|
115
|
-
const protocolIndex = match.indexOf(p3);
|
|
116
|
-
const end = match.substring(protocolIndex + p3.length);
|
|
117
|
-
return [
|
|
118
|
-
`${begin}${PREFIX}${p1}`,
|
|
119
|
-
`${match.substring(beginIndex + p1.length, protocolIndex)}`,
|
|
120
|
-
`${objInstances[p3]||p3}`,
|
|
121
|
-
`${end}`
|
|
122
|
-
].join('');
|
|
123
|
-
} else {
|
|
124
|
-
const beginIndex = match.indexOf(p1);
|
|
125
|
-
const begin = match.substring(0, beginIndex);
|
|
126
|
-
const end = match.substring(beginIndex + p1.length);
|
|
127
|
-
return `${begin}${PREFIX}${p1}${end}`;
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
// replace implementation
|
|
132
|
-
// TODO: replace protocol too
|
|
133
|
-
content = content.replace(RegExp(`\\s*@implementation\\s*(${escapeRegExp(file)})`), (match, p1) => {
|
|
134
|
-
let beginIndex = match.indexOf(p1);
|
|
135
|
-
let begin = match.substring(0, beginIndex);
|
|
136
|
-
let end = match.substring(beginIndex + p1.length);
|
|
137
|
-
return `${begin}${PREFIX}${p1}${end}`;
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
// replace vars
|
|
141
|
-
Object.entries(objInstances).forEach(([oldName, newName]) => {
|
|
142
|
-
content = content.replace(RegExp(`\\b(${escapeRegExp(oldName)})\\s*(<\\w+>)?\\s*\\*`, 'g'), (match, p1) => {
|
|
143
|
-
const beginIndex = match.indexOf(p1);
|
|
144
|
-
const begin = match.substring(0, beginIndex);
|
|
145
|
-
const end = match.substring(beginIndex + p1.length);
|
|
146
|
-
return `${begin}${newName}${end}`;
|
|
147
|
-
});
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
// replace static method calls
|
|
151
|
-
Object.entries(objInstances).forEach(([oldName, newName]) => {
|
|
152
|
-
content = content.replace(RegExp(`\\[(${escapeRegExp(oldName)})\\s+.*\\]`, 'g'), (match, p1) => {
|
|
153
|
-
const beginIndex = match.indexOf(p1);
|
|
154
|
-
const begin = match.substring(0, beginIndex);
|
|
155
|
-
const end = match.substring(beginIndex + p1.length);
|
|
156
|
-
return `${begin}${newName}${end}`;
|
|
157
|
-
});
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
fs.renameSync(oldPath, newPath);
|
|
161
|
-
fs.writeFileSync(newPath, content);
|
|
162
|
-
|
|
163
|
-
return {
|
|
164
|
-
oldPath,
|
|
165
|
-
newPath,
|
|
166
|
-
imports,
|
|
167
|
-
newImports: imports.map(imp => refactorTable[imp]||imp)
|
|
168
|
-
}
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
let pbxProj = fs.readFileSync(PBX_PROJ, 'utf8');
|
|
172
|
-
Object.keys(refactorTable).forEach(fileName => {
|
|
173
|
-
pbxProj = pbxProj.replace(RegExp(`\\b(${escapeRegExp(fileName)})`, 'g'), (match, fileName) => {
|
|
174
|
-
const beginIndex = match.indexOf(fileName);
|
|
175
|
-
const begin = match.substring(0, beginIndex);
|
|
176
|
-
const end = match.substring(beginIndex + fileName.length);
|
|
177
|
-
const refactoredFileName = refactorTable[fileName];
|
|
178
|
-
return `${begin}${refactoredFileName}${end}`;
|
|
179
|
-
});
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
fs.writeFileSync(PBX_PROJ, pbxProj);
|
|
183
|
-
|
|
184
|
-
console.log(ref);
|