@react-native-firebase/storage 16.0.0 → 16.1.0
Sign up to get free protection for your applications and to get access to all the features.
package/CHANGELOG.md
CHANGED
@@ -3,6 +3,12 @@
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
5
5
|
|
6
|
+
## [16.1.0](https://github.com/invertase/react-native-firebase/compare/v16.0.0...v16.1.0) (2022-10-20)
|
7
|
+
|
8
|
+
### Bug Fixes
|
9
|
+
|
10
|
+
- **storage, emulator:** avoid calling useEmulator multiple times ([276630d](https://github.com/invertase/react-native-firebase/commit/276630d4690cb6c3b2b632ec9dd0808ca8013eba)), closes [#5860](https://github.com/invertase/react-native-firebase/issues/5860)
|
11
|
+
|
6
12
|
## [16.0.0](https://github.com/invertase/react-native-firebase/compare/v15.7.1...v16.0.0) (2022-10-19)
|
7
13
|
|
8
14
|
**Note:** Version bump only for package @react-native-firebase/storage
|
package/android/src/main/java/io/invertase/firebase/storage/ReactNativeFirebaseStorageModule.java
CHANGED
@@ -44,6 +44,8 @@ import java.util.Objects;
|
|
44
44
|
public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule {
|
45
45
|
private static final String TAG = "Storage";
|
46
46
|
|
47
|
+
private static HashMap<String, String> emulatorConfigs = new HashMap<>();
|
48
|
+
|
47
49
|
ReactNativeFirebaseStorageModule(ReactApplicationContext reactContext) {
|
48
50
|
super(reactContext, TAG);
|
49
51
|
}
|
@@ -54,7 +56,9 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
54
56
|
super.onCatalystInstanceDestroy();
|
55
57
|
}
|
56
58
|
|
57
|
-
/**
|
59
|
+
/**
|
60
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#delete
|
61
|
+
*/
|
58
62
|
@ReactMethod
|
59
63
|
public void delete(String appName, String url, final Promise promise) {
|
60
64
|
try {
|
@@ -97,7 +101,9 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
97
101
|
}
|
98
102
|
}
|
99
103
|
|
100
|
-
/**
|
104
|
+
/**
|
105
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#getMetadata
|
106
|
+
*/
|
101
107
|
@ReactMethod
|
102
108
|
public void getMetadata(String appName, String url, Promise promise) {
|
103
109
|
try {
|
@@ -118,7 +124,9 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
118
124
|
}
|
119
125
|
}
|
120
126
|
|
121
|
-
/**
|
127
|
+
/**
|
128
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#list
|
129
|
+
*/
|
122
130
|
@ReactMethod
|
123
131
|
public void list(String appName, String url, ReadableMap listOptions, Promise promise) {
|
124
132
|
try {
|
@@ -148,7 +156,9 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
148
156
|
}
|
149
157
|
}
|
150
158
|
|
151
|
-
/**
|
159
|
+
/**
|
160
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#listAll
|
161
|
+
*/
|
152
162
|
@ReactMethod
|
153
163
|
public void listAll(String appName, String url, Promise promise) {
|
154
164
|
try {
|
@@ -267,16 +277,23 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
267
277
|
promise.resolve(null);
|
268
278
|
}
|
269
279
|
|
270
|
-
/**
|
280
|
+
/**
|
281
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Storage#useEmulator
|
282
|
+
*/
|
271
283
|
@ReactMethod
|
272
284
|
public void useEmulator(String appName, String host, int port, Promise promise) {
|
273
285
|
FirebaseApp firebaseApp = FirebaseApp.getInstance(appName);
|
274
286
|
FirebaseStorage firebaseStorage = FirebaseStorage.getInstance(firebaseApp);
|
275
|
-
|
287
|
+
if (emulatorConfigs.get(appName) == null) {
|
288
|
+
firebaseStorage.useEmulator(host, port);
|
289
|
+
emulatorConfigs.put(appName, "true");
|
290
|
+
}
|
276
291
|
promise.resolve(null);
|
277
292
|
}
|
278
293
|
|
279
|
-
/**
|
294
|
+
/**
|
295
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#writeToFile
|
296
|
+
*/
|
280
297
|
@ReactMethod
|
281
298
|
public void writeToFile(
|
282
299
|
String appName, String url, String localFilePath, int taskId, Promise promise) {
|
@@ -300,7 +317,9 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
300
317
|
}
|
301
318
|
}
|
302
319
|
|
303
|
-
/**
|
320
|
+
/**
|
321
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#putString
|
322
|
+
*/
|
304
323
|
@ReactMethod
|
305
324
|
public void putString(
|
306
325
|
String appName,
|
@@ -321,7 +340,9 @@ public class ReactNativeFirebaseStorageModule extends ReactNativeFirebaseModule
|
|
321
340
|
}
|
322
341
|
}
|
323
342
|
|
324
|
-
/**
|
343
|
+
/**
|
344
|
+
* @link https://firebase.google.com/docs/reference/js/firebase.storage.Reference#putFile
|
345
|
+
*/
|
325
346
|
@ReactMethod
|
326
347
|
public void putFile(
|
327
348
|
String appName,
|
@@ -35,7 +35,7 @@ static NSMutableDictionary *PENDING_TASKS;
|
|
35
35
|
// The iOS SDK has a short memory on settings, store these globally and set them in each time
|
36
36
|
static NSString *emulatorHost = nil;
|
37
37
|
static NSInteger emulatorPort = 0;
|
38
|
-
static
|
38
|
+
static NSMutableDictionary *emulatorConfigs;
|
39
39
|
static NSTimeInterval maxDownloadRetryTime = 600;
|
40
40
|
static NSTimeInterval maxUploadRetryTime = 600;
|
41
41
|
static NSTimeInterval maxOperationRetryTime = 120;
|
@@ -56,6 +56,7 @@ RCT_EXPORT_MODULE();
|
|
56
56
|
static dispatch_once_t onceToken;
|
57
57
|
dispatch_once(&onceToken, ^{
|
58
58
|
PENDING_TASKS = [[NSMutableDictionary alloc] init];
|
59
|
+
emulatorConfigs = [[NSMutableDictionary alloc] init];
|
59
60
|
});
|
60
61
|
|
61
62
|
return self;
|
@@ -506,12 +507,10 @@ RCT_EXPORT_METHOD(useEmulator
|
|
506
507
|
: (NSInteger)port) {
|
507
508
|
emulatorHost = host;
|
508
509
|
emulatorPort = port;
|
509
|
-
if (
|
510
|
-
|
510
|
+
if (!emulatorConfigs[firebaseApp.name]) {
|
511
|
+
[[FIRStorage storageForApp:firebaseApp] useEmulatorWithHost:host port:port];
|
512
|
+
emulatorConfigs[firebaseApp.name] = @YES;
|
511
513
|
}
|
512
|
-
|
513
|
-
[[FIRStorage storageForApp:firebaseApp] useEmulatorWithHost:host port:port];
|
514
|
-
useEmulatorCalled = true;
|
515
514
|
}
|
516
515
|
|
517
516
|
/**
|
@@ -669,10 +668,11 @@ RCT_EXPORT_METHOD(setTaskStatus
|
|
669
668
|
storage = [FIRStorage storageForApp:firebaseApp URL:bucket];
|
670
669
|
|
671
670
|
NSLog(@"Setting emulator - host %@ port %ld", emulatorHost, (long)emulatorPort);
|
672
|
-
if (![emulatorHost isEqual:[NSNull null]] && emulatorHost != nil &&
|
671
|
+
if (![emulatorHost isEqual:[NSNull null]] && emulatorHost != nil &&
|
672
|
+
!emulatorConfigs[firebaseApp.name]) {
|
673
673
|
@try {
|
674
674
|
[storage useEmulatorWithHost:emulatorHost port:emulatorPort];
|
675
|
-
|
675
|
+
emulatorConfigs[firebaseApp.name] = @YES;
|
676
676
|
} @catch (NSException *e) {
|
677
677
|
NSLog(@"WARNING: Unable to set the Firebase Storage emulator settings. These must be set "
|
678
678
|
@"before any usages of Firebase Storage. If you see this log after a hot "
|
package/lib/version.js
CHANGED
@@ -1,2 +1,2 @@
|
|
1
1
|
// Generated by genversion.
|
2
|
-
module.exports = '16.
|
2
|
+
module.exports = '16.1.0';
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@react-native-firebase/storage",
|
3
|
-
"version": "16.
|
3
|
+
"version": "16.1.0",
|
4
4
|
"author": "Invertase <oss@invertase.io> (http://invertase.io)",
|
5
5
|
"description": "React Native Firebase - React Native Firebase provides native integration with Cloud Storage, providing support to upload and download files directly from your device and from your Firebase Cloud Storage bucket.",
|
6
6
|
"main": "lib/index.js",
|
@@ -29,10 +29,10 @@
|
|
29
29
|
"download"
|
30
30
|
],
|
31
31
|
"peerDependencies": {
|
32
|
-
"@react-native-firebase/app": "16.
|
32
|
+
"@react-native-firebase/app": "16.1.0"
|
33
33
|
},
|
34
34
|
"publishConfig": {
|
35
35
|
"access": "public"
|
36
36
|
},
|
37
|
-
"gitHead": "
|
37
|
+
"gitHead": "f2d1363b89fb046388f8336b08852c1ea0c285f2"
|
38
38
|
}
|