2022-09-28 12:08:16 +00:00
|
|
|
import React, { useRef } from 'react';
|
|
|
|
import { WebView, WebViewMessageEvent } from 'react-native-webview';
|
|
|
|
import { SafeAreaView, Text, Platform } from 'react-native';
|
|
|
|
import { torClient } from './services/Tor';
|
|
|
|
|
|
|
|
const App = () => {
|
|
|
|
const webViewRef = useRef<WebView>();
|
|
|
|
const uri = (Platform.OS === 'android' ? 'file:///android_asset/' : '') + 'Web.bundle/index.html';
|
|
|
|
|
|
|
|
const injectMessage = (id: string, data: object) => {
|
|
|
|
const json = JSON.stringify(data);
|
|
|
|
webViewRef.current?.injectJavaScript(
|
|
|
|
`(function() {window.NativeRobosats.onMessageResolve(${id}, ${json});})();`,
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const onMessage = async (event: WebViewMessageEvent) => {
|
|
|
|
const data = JSON.parse(event.nativeEvent.data);
|
|
|
|
if (data.category === 'http') {
|
|
|
|
if (data.type === 'get') {
|
|
|
|
torClient.get(data.path).then((response: object) => {
|
|
|
|
injectMessage(data.id, response);
|
|
|
|
});
|
|
|
|
} else if (data.type === 'post') {
|
|
|
|
torClient.post(data.path, data.body, data.headers).then((response: object) => {
|
|
|
|
injectMessage(data.id, response);
|
|
|
|
});
|
|
|
|
} else if (data.type === 'delete') {
|
|
|
|
torClient.delete(data.path, data.headers).then((response: object) => {
|
|
|
|
injectMessage(data.id, response);
|
|
|
|
});
|
|
|
|
} else if (data.type === 'xhr') {
|
|
|
|
torClient.request(data.path).then((response: object) => {
|
|
|
|
injectMessage(data.id, response);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
torClient.startDaemon();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<SafeAreaView style={{ flex: 1 }}>
|
|
|
|
<WebView
|
|
|
|
source={{
|
|
|
|
uri,
|
|
|
|
}}
|
|
|
|
onMessage={onMessage}
|
|
|
|
// @ts-expect-error
|
|
|
|
ref={(ref) => (webViewRef.current = ref)}
|
2022-10-04 16:00:37 +00:00
|
|
|
overScrollMode='never'
|
2022-09-28 12:08:16 +00:00
|
|
|
javaScriptEnabled={true}
|
|
|
|
domStorageEnabled={true}
|
|
|
|
sharedCookiesEnabled={true}
|
|
|
|
thirdPartyCookiesEnabled={true}
|
|
|
|
originWhitelist={[uri]}
|
|
|
|
scalesPageToFit={true}
|
|
|
|
startInLoadingState={true}
|
|
|
|
mixedContentMode={'always'}
|
|
|
|
allowsInlineMediaPlayback={true}
|
|
|
|
allowsFullscreenVideo={false}
|
|
|
|
setBuiltInZoomControls={false}
|
|
|
|
allowingReadAccessToURL={uri}
|
|
|
|
allowFileAccess={true}
|
|
|
|
allowsBackForwardNavigationGestures={false}
|
|
|
|
mediaPlaybackRequiresUserAction={false}
|
|
|
|
allowsLinkPreview={false}
|
|
|
|
renderLoading={() => <Text>Loading RoboSats</Text>}
|
|
|
|
onError={(syntheticEvent) => <Text>{syntheticEvent.type}</Text>}
|
|
|
|
/>
|
|
|
|
</SafeAreaView>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default App;
|