mirror of
https://github.com/status-im/react-native-tcp.git
synced 2025-01-27 02:34:45 +00:00
refactor android, remove useless callbacks
This commit is contained in:
parent
ab0e3d91c5
commit
6a56aedebf
@ -162,9 +162,9 @@ TcpSocket.prototype.end = function(data, encoding) {
|
||||
}
|
||||
|
||||
this._destroyed = true;
|
||||
this._debug('closing');
|
||||
this._debug('ending');
|
||||
|
||||
Sockets.end(this._id, this._debug.bind(this, 'end'));
|
||||
Sockets.end(this._id);
|
||||
};
|
||||
|
||||
TcpSocket.prototype.destroy = function() {
|
||||
@ -172,7 +172,7 @@ TcpSocket.prototype.destroy = function() {
|
||||
this._destroyed = true;
|
||||
this._debug('destroying');
|
||||
|
||||
Sockets.destroy(this._id, this._debug.bind(this, 'destroy'));
|
||||
Sockets.destroy(this._id);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -1,3 +1,5 @@
|
||||
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||
|
||||
buildscript {
|
||||
repositories {
|
||||
jcenter()
|
||||
@ -5,40 +7,14 @@ buildscript {
|
||||
|
||||
dependencies {
|
||||
classpath 'com.android.tools.build:gradle:1.3.1'
|
||||
|
||||
// NOTE: Do not place your application dependencies here; they belong
|
||||
// in the individual module build.gradle files
|
||||
}
|
||||
}
|
||||
|
||||
apply plugin: 'com.android.library'
|
||||
|
||||
android {
|
||||
compileSdkVersion 23
|
||||
buildToolsVersion "23.0.1"
|
||||
|
||||
defaultConfig {
|
||||
minSdkVersion 16
|
||||
targetSdkVersion 22
|
||||
versionCode 1
|
||||
versionName "0.2.0"
|
||||
}
|
||||
|
||||
buildTypes {
|
||||
release {
|
||||
minifyEnabled false
|
||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
||||
}
|
||||
}
|
||||
|
||||
// needed for https://github.com/square/okio/issues/58
|
||||
lintOptions {
|
||||
warning 'InvalidPackage'
|
||||
allprojects {
|
||||
repositories {
|
||||
jcenter()
|
||||
}
|
||||
}
|
||||
|
||||
repositories {
|
||||
mavenCentral()
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compile 'com.facebook.react:react-native:0.17.+'
|
||||
compile 'com.koushikdutta.async:androidasync:2.1.6'
|
||||
}
|
||||
|
30
android/core/build.gradle
Normal file
30
android/core/build.gradle
Normal file
@ -0,0 +1,30 @@
|
||||
apply plugin: 'com.android.library'
|
||||
|
||||
android {
|
||||
compileSdkVersion 23
|
||||
buildToolsVersion "23.0.1"
|
||||
|
||||
defaultConfig {
|
||||
minSdkVersion 16
|
||||
targetSdkVersion 22
|
||||
versionCode 1
|
||||
versionName "0.2.0"
|
||||
}
|
||||
|
||||
buildTypes {
|
||||
release {
|
||||
minifyEnabled false
|
||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
||||
}
|
||||
}
|
||||
|
||||
// needed for https://github.com/square/okio/issues/58
|
||||
lintOptions {
|
||||
warning 'InvalidPackage'
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compile 'com.facebook.react:react-native:0.17.+'
|
||||
compile 'com.koushikdutta.async:androidasync:2.1.6'
|
||||
}
|
17
android/core/proguard-rules.pro
vendored
Normal file
17
android/core/proguard-rules.pro
vendored
Normal file
@ -0,0 +1,17 @@
|
||||
# Add project specific ProGuard rules here.
|
||||
# By default, the flags in this file are appended to flags specified
|
||||
# in /usr/local/Cellar/android-sdk/24.3.3/tools/proguard/proguard-android.txt
|
||||
# You can edit the include path and order by changing the proguardFiles
|
||||
# directive in build.gradle.
|
||||
#
|
||||
# For more details, see
|
||||
# http://developer.android.com/guide/developing/tools/proguard.html
|
||||
|
||||
# Add any project specific keep options here:
|
||||
|
||||
# If your project uses WebView with JS, uncomment the following
|
||||
# and specify the fully qualified class name to the JavaScript interface
|
||||
# class:
|
||||
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
||||
# public *;
|
||||
#}
|
@ -2,6 +2,4 @@
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
package="com.peel.react" >
|
||||
<uses-permission android:name="android.permission.INTERNET"/>
|
||||
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
|
||||
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
|
||||
</manifest>
|
@ -22,33 +22,25 @@ import java.net.UnknownHostException;
|
||||
/**
|
||||
* Created by aprock on 12/29/15.
|
||||
*/
|
||||
public class TcpSocketManager {
|
||||
public final class TcpSocketManager {
|
||||
private SparseArray<Object> mClients = new SparseArray<Object>();
|
||||
|
||||
private WeakReference<TcpSocketListener> listener;
|
||||
private AsyncServer server = AsyncServer.getDefault();
|
||||
private WeakReference<TcpSocketListener> mListener;
|
||||
private AsyncServer mServer = AsyncServer.getDefault();
|
||||
|
||||
private int instances = 5000;
|
||||
private int mInstances = 5000;
|
||||
|
||||
public TcpSocketManager(TcpSocketListener listener) throws IOException {
|
||||
this.listener = new WeakReference<TcpSocketListener>(listener);
|
||||
}
|
||||
|
||||
private TcpSocketListener getListener() {
|
||||
if (listener != null) {
|
||||
return listener.get();
|
||||
}
|
||||
|
||||
return null;
|
||||
mListener = new WeakReference<TcpSocketListener>(listener);
|
||||
}
|
||||
|
||||
private void setSocketCallbacks(final Integer cId, final AsyncSocket socket) {
|
||||
socket.setClosedCallback(new CompletedCallback() {
|
||||
@Override
|
||||
public void onCompleted(Exception ex) {
|
||||
TcpSocketListener listener = getListener();
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onClose(cId, null);
|
||||
listener.onClose(cId, ex==null?null:ex.getMessage());
|
||||
}
|
||||
}
|
||||
});
|
||||
@ -56,7 +48,7 @@ public class TcpSocketManager {
|
||||
socket.setDataCallback(new DataCallback() {
|
||||
@Override
|
||||
public void onDataAvailable(DataEmitter emitter, ByteBufferList bb) {
|
||||
TcpSocketListener listener = getListener();
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onData(cId, bb.getAllByteArray());
|
||||
}
|
||||
@ -67,7 +59,7 @@ public class TcpSocketManager {
|
||||
@Override
|
||||
public void onCompleted(Exception ex) {
|
||||
if (ex != null) {
|
||||
TcpSocketListener listener = getListener();
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onError(cId, ex.getMessage());
|
||||
}
|
||||
@ -86,12 +78,12 @@ public class TcpSocketManager {
|
||||
socketAddress = new InetSocketAddress(port);
|
||||
}
|
||||
|
||||
server.listen(InetAddress.getByName(host), port, new ListenCallback() {
|
||||
mServer.listen(InetAddress.getByName(host), port, new ListenCallback() {
|
||||
@Override
|
||||
public void onListening(AsyncServerSocket socket) {
|
||||
mClients.put(cId, socket);
|
||||
|
||||
TcpSocketListener listener = getListener();
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onConnect(cId, socketAddress);
|
||||
}
|
||||
@ -99,25 +91,25 @@ public class TcpSocketManager {
|
||||
|
||||
@Override
|
||||
public void onAccepted(AsyncSocket socket) {
|
||||
setSocketCallbacks(instances, socket);
|
||||
mClients.put(instances, socket);
|
||||
setSocketCallbacks(mInstances, socket);
|
||||
mClients.put(mInstances, socket);
|
||||
|
||||
TcpSocketListener listener = getListener();
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onConnection(cId, instances, socketAddress);
|
||||
listener.onConnection(cId, mInstances, socketAddress);
|
||||
}
|
||||
|
||||
instances++;
|
||||
mInstances++;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCompleted(Exception ex) {
|
||||
TcpSocketListener listener = getListener();
|
||||
mClients.delete(cId);
|
||||
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onClose(cId, ex != null ? ex.getMessage() : null);
|
||||
}
|
||||
|
||||
mClients.remove(cId);
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -131,22 +123,19 @@ public class TcpSocketManager {
|
||||
socketAddress = new InetSocketAddress(port);
|
||||
}
|
||||
|
||||
server.connectSocket(socketAddress, new ConnectCallback() {
|
||||
mServer.connectSocket(socketAddress, new ConnectCallback() {
|
||||
@Override
|
||||
public void onConnectCompleted(Exception ex, AsyncSocket socket) {
|
||||
if (ex != null) {
|
||||
TcpSocketListener listener = getListener();
|
||||
if (listener != null) {
|
||||
listener.onError(cId, ex.getMessage());
|
||||
}
|
||||
} else {
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (ex == null) {
|
||||
mClients.put(cId, socket);
|
||||
setSocketCallbacks(cId, socket);
|
||||
|
||||
TcpSocketListener listener = getListener();
|
||||
if (listener != null) {
|
||||
listener.onConnect(cId, socketAddress);
|
||||
}
|
||||
} else if (listener != null) {
|
||||
listener.onError(cId, ex.getMessage());
|
||||
}
|
||||
}
|
||||
});
|
||||
@ -161,15 +150,18 @@ public class TcpSocketManager {
|
||||
|
||||
public void close(final Integer cId) {
|
||||
Object socket = mClients.get(cId);
|
||||
if (socket == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (socket != null) {
|
||||
if (socket instanceof AsyncSocket) {
|
||||
((AsyncSocket) socket).close();
|
||||
} else if (socket instanceof AsyncServerSocket) {
|
||||
((AsyncServerSocket) socket).stop();
|
||||
}
|
||||
} else {
|
||||
TcpSocketListener listener = mListener.get();
|
||||
if (listener != null) {
|
||||
listener.onError(cId, "unable to find socket");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void closeAllSockets() {
|
||||
@ -177,4 +169,5 @@ public class TcpSocketManager {
|
||||
close(mClients.keyAt(i));
|
||||
}
|
||||
mClients.clear();
|
||||
}}
|
||||
}
|
||||
}
|
@ -124,7 +124,7 @@ public final class TcpSockets extends ReactContextBaseJavaModule implements TcpS
|
||||
}
|
||||
|
||||
@ReactMethod
|
||||
public void end(final Integer cId, final Callback callback) {
|
||||
public void end(final Integer cId) {
|
||||
new GuardedAsyncTask<Void, Void>(getReactApplicationContext()) {
|
||||
@Override
|
||||
protected void doInBackgroundGuarded(Void... params) {
|
||||
@ -134,8 +134,8 @@ public final class TcpSockets extends ReactContextBaseJavaModule implements TcpS
|
||||
}
|
||||
|
||||
@ReactMethod
|
||||
public void destroy(final Integer cId, final Callback callback) {
|
||||
end(cId, callback);
|
||||
public void destroy(final Integer cId) {
|
||||
end(cId);
|
||||
}
|
||||
|
||||
/** TcpSocketListener */
|
0
android/gradlew
vendored
Normal file → Executable file
0
android/gradlew
vendored
Normal file → Executable file
1
android/settings.gradle
Normal file
1
android/settings.gradle
Normal file
@ -0,0 +1 @@
|
||||
include ':core'
|
@ -2,4 +2,4 @@ rootProject.name = 'rctsockets'
|
||||
|
||||
include ':app'
|
||||
include ':react-native-tcp'
|
||||
project(':react-native-tcp').projectDir = new File(settingsDir, '../node_modules/react-native-tcp/android')
|
||||
project(':react-native-tcp').projectDir = new File(settingsDir, '../node_modules/react-native-tcp/android/core')
|
||||
|
@ -27,7 +27,7 @@ RCT_EXPORT_MODULE()
|
||||
-(void)dealloc
|
||||
{
|
||||
for (NSNumber *cId in _clients.allKeys) {
|
||||
[self destroyClient:cId callback:nil];
|
||||
[self destroyClient:cId];
|
||||
}
|
||||
}
|
||||
|
||||
@ -73,7 +73,7 @@ RCT_EXPORT_METHOD(connect:(nonnull NSNumber*)cId
|
||||
RCT_EXPORT_METHOD(write:(nonnull NSNumber*)cId
|
||||
string:(NSString *)base64String
|
||||
callback:(RCTResponseSenderBlock)callback) {
|
||||
TcpSocketClient* client = [self findClient:cId callback:callback];
|
||||
TcpSocketClient* client = [self findClient:cId];
|
||||
if (!client) return;
|
||||
|
||||
// iOS7+
|
||||
@ -82,14 +82,12 @@ RCT_EXPORT_METHOD(write:(nonnull NSNumber*)cId
|
||||
[client writeData:data callback:callback];
|
||||
}
|
||||
|
||||
RCT_EXPORT_METHOD(end:(nonnull NSNumber*)cId
|
||||
callback:(RCTResponseSenderBlock)callback) {
|
||||
[self endClient:cId callback:callback];
|
||||
RCT_EXPORT_METHOD(end:(nonnull NSNumber*)cId) {
|
||||
[self endClient:cId];
|
||||
}
|
||||
|
||||
RCT_EXPORT_METHOD(destroy:(nonnull NSNumber*)cId
|
||||
callback:(RCTResponseSenderBlock)callback) {
|
||||
[self destroyClient:cId callback:callback];
|
||||
RCT_EXPORT_METHOD(destroy:(nonnull NSNumber*)cId) {
|
||||
[self destroyClient:cId];
|
||||
}
|
||||
|
||||
RCT_EXPORT_METHOD(listen:(nonnull NSNumber*)cId
|
||||
@ -143,22 +141,19 @@ RCT_EXPORT_METHOD(listen:(nonnull NSNumber*)cId
|
||||
}
|
||||
|
||||
- (void)onError:(TcpSocketClient*) client withError:(NSError *)err {
|
||||
NSString *msg = [err userInfo][@"NSLocalizedFailureReason"] ?: [err userInfo][@"NSLocalizedDescription"];
|
||||
NSString *msg = err.localizedFailureReason ?: err.localizedDescription;
|
||||
[self.bridge.eventDispatcher sendDeviceEventWithName:[NSString stringWithFormat:@"tcp-%@-error", client.id]
|
||||
body:msg];
|
||||
|
||||
}
|
||||
|
||||
-(TcpSocketClient*)findClient:(nonnull NSNumber*)cId callback:(RCTResponseSenderBlock)callback
|
||||
-(TcpSocketClient*)findClient:(nonnull NSNumber*)cId
|
||||
{
|
||||
TcpSocketClient *client = _clients[cId];
|
||||
if (!client) {
|
||||
if (!callback) {
|
||||
RCTLogError(@"%@.missing callback parameter.", [self class]);
|
||||
} else {
|
||||
callback(@[[NSString stringWithFormat:@"no client found with id %@", cId]]);
|
||||
}
|
||||
|
||||
NSString *msg = [NSString stringWithFormat:@"no client found with id %@", cId];
|
||||
[self.bridge.eventDispatcher sendDeviceEventWithName:[NSString stringWithFormat:@"tcp-%@-error", cId]
|
||||
body:msg];
|
||||
return nil;
|
||||
}
|
||||
|
||||
@ -166,20 +161,16 @@ RCT_EXPORT_METHOD(listen:(nonnull NSNumber*)cId
|
||||
}
|
||||
|
||||
-(void)endClient:(nonnull NSNumber*)cId
|
||||
callback:(RCTResponseSenderBlock)callback
|
||||
{
|
||||
TcpSocketClient* client = [self findClient:cId callback:callback];
|
||||
TcpSocketClient* client = [self findClient:cId];
|
||||
if (!client) return;
|
||||
|
||||
[client end];
|
||||
|
||||
if (callback) callback(@[]);
|
||||
}
|
||||
|
||||
-(void)destroyClient:(nonnull NSNumber*)cId
|
||||
callback:(RCTResponseSenderBlock)callback
|
||||
{
|
||||
TcpSocketClient* client = [self findClient:cId callback:nil];
|
||||
TcpSocketClient* client = [self findClient:cId];
|
||||
if (!client) return;
|
||||
|
||||
[client destroy];
|
||||
|
Loading…
x
Reference in New Issue
Block a user