2
0
mirror of synced 2025-01-24 21:30:16 +00:00

Merge pull request #1215 from ctaintor/add_instanceid_methods

adds support for getToken(string,string) and deleteToken()
This commit is contained in:
Chris Bianca 2018-06-18 15:02:18 +01:00 committed by GitHub
commit d7d6124fc8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 113 additions and 1 deletions

View File

@ -1,6 +1,8 @@
package io.invertase.firebase.instanceid;
import java.io.IOException;
import android.util.Log;
import com.facebook.react.bridge.Promise;
@ -42,4 +44,26 @@ public class RNFirebaseInstanceId extends ReactContextBaseJavaModule {
String id = FirebaseInstanceId.getInstance().getId();
promise.resolve(id);
}
@ReactMethod
public void getToken(String authorizedEntity, String scope, Promise promise) {
try {
String token = FirebaseInstanceId.getInstance().getToken(authorizedEntity, scope);
Log.d(TAG, "Firebase token for " + authorizedEntity + ": " + token);
promise.resolve(token);
} catch (IOException e) {
promise.reject("iid/request-failed", "getToken request failed", e);
}
}
@ReactMethod
public void deleteToken(String authorizedEntity, String scope, Promise promise) {
try {
FirebaseInstanceId.getInstance().deleteToken(authorizedEntity, scope);
Log.d(TAG, "Firebase token deleted for " + authorizedEntity);
promise.resolve(null);
} catch (IOException e) {
promise.reject("iid/request-failed", "deleteToken request failed", e);
}
}
}

View File

@ -1,6 +1,7 @@
#import "RNFirebaseInstanceId.h"
#if __has_include(<FirebaseInstanceID/FIRInstanceID.h>)
#import <FirebaseMessaging/FirebaseMessaging.h>
#import <FirebaseInstanceID/FIRInstanceID.h>
@implementation RNFirebaseInstanceId
@ -26,6 +27,36 @@ RCT_EXPORT_METHOD(get:(RCTPromiseResolveBlock)resolve rejecter:(RCTPromiseReject
}];
}
RCT_EXPORT_METHOD(getToken:(NSString *)authorizedEntity
scope:(NSString *)scope
resolver:(RCTPromiseResolveBlock)resolve
rejecter:(RCTPromiseRejectBlock)reject) {
NSDictionary * options = nil;
if ([FIRMessaging messaging].APNSToken) {
options = @{@"apns_token": [FIRMessaging messaging].APNSToken};
}
[[FIRInstanceID instanceID] tokenWithAuthorizedEntity:authorizedEntity scope:scope options:options handler:^(NSString * _Nullable identity, NSError * _Nullable error) {
if (error) {
reject(@"instance_id_error", @"Failed to getToken", error);
} else {
resolve(identity);
}
}];
}
RCT_EXPORT_METHOD(deleteToken:(NSString *)authorizedEntity
scope:(NSString *)scope
resolver:(RCTPromiseResolveBlock)resolve
rejecter:(RCTPromiseRejectBlock)reject) {
[[FIRInstanceID instanceID] deleteTokenWithAuthorizedEntity:authorizedEntity scope:scope handler:^(NSError * _Nullable error) {
if (error) {
reject(@"instance_id_error", @"Failed to deleteToken", error);
} else {
resolve(nil);
}
}];
}
@end
#else

2
lib/index.d.ts vendored
View File

@ -1088,6 +1088,8 @@ declare module 'react-native-firebase' {
interface InstanceId {
delete(): Promise<void>;
get(): Promise<string>;
getToken(authorizedEntity: string, scope: string): Promise<string>;
deleteToken(authorizedEntity: string, scope: string): Promise<void>;
}
}

View File

@ -27,6 +27,14 @@ export default class InstanceId extends ModuleBase {
get(): Promise<string> {
return getNativeModule(this).get();
}
getToken(authorizedEntity: string, scope: string): Promise<string> {
return getNativeModule(this).getToken(authorizedEntity, scope);
}
deleteToken(authorizedEntity: string, scope: string): Promise<void> {
return getNativeModule(this).deleteToken(authorizedEntity, scope);
}
}
export const statics = {};

View File

@ -225,7 +225,7 @@ PODS:
- React/Core
- React/fishhook
- React/RCTBlob
- RNFirebase (4.1.0):
- RNFirebase (4.2.0):
- Firebase/Core
- React
- yoga (0.54.4.React)

View File

@ -0,0 +1,35 @@
import should from 'should';
function iidTests({ describe, it, firebase }) {
describe('iid', () => {
it('should delete the iid token', async () => {
await firebase.native.iid().delete();
});
it('it should return iid token from get', async () => {
const token = await firebase.native.iid().get();
token.should.be.a.String();
});
it('should return an FCM token from getToken with arguments', async () => {
await firebase.native.iid().delete();
const otherSenderIdToken = await firebase.native
.iid()
.getToken('305229645282', '*');
otherSenderIdToken.should.be.a.String();
});
it('should return nil from deleteToken', async () => {
const token = await firebase.native
.iid()
.deleteToken('305229645282', '*');
should.not.exist(token);
});
});
}
export default iidTests;

View File

@ -0,0 +1,10 @@
import firebase from '../../firebase';
import TestSuite from '../../../lib/TestSuite';
import iidTests from './iidTests';
const suite = new TestSuite('Iid', 'firebase.id()', firebase);
suite.addTests(iidTests);
export default suite;

View File

@ -12,6 +12,7 @@ import performance from './perf';
import admob from './admob';
import firestore from './firestore';
import links from './links/index';
import iid from './iid';
window.getCoverage = function getCoverage() {
return JSON.stringify(global.__coverage__);
@ -31,6 +32,7 @@ const testSuiteInstances = [
performance,
storage,
links,
iid,
];
/*