fix sms otp retriver
This commit is contained in:
@@ -25,15 +25,10 @@ import {
|
||||
FreechargePersonalBindResult,
|
||||
GooglePayBusinessBindResult,
|
||||
BharatPeBusinessBindResult,
|
||||
onSmsMessage,
|
||||
startSmsListener,
|
||||
stopSmsListener,
|
||||
checkSmsPermission,
|
||||
requestSmsPermission,
|
||||
PhonePePersonalBind,
|
||||
FreechargePersonalBind,
|
||||
SmsMessage,
|
||||
proxyBackgroundService,
|
||||
type TokenAutoRebindDeps,
|
||||
PhonePePersonalBindResult,
|
||||
PaytmPersonalBindResult,
|
||||
BindErrorCode,
|
||||
@@ -58,10 +53,8 @@ import Api, {
|
||||
loadServerDomain,
|
||||
getServerDomain,
|
||||
getTokenAutoRebindEnabled,
|
||||
getTokenAutoRebindDebug,
|
||||
getTokenAutoRebindOptions,
|
||||
saveTokenAutoRebindEnabled,
|
||||
saveTokenAutoRebindDebug,
|
||||
} from '../services/api';
|
||||
|
||||
function formatWalletTypeLabel(walletType: string) {
|
||||
@@ -130,7 +123,6 @@ interface HomeScreenState {
|
||||
proxyStatus: 'idle' | 'connecting' | 'connected' | 'disconnected' | 'error';
|
||||
proxyError?: string;
|
||||
tokenAutoRebind: boolean;
|
||||
tokenAutoRebindDebug: boolean;
|
||||
// server settings
|
||||
showServerSettings: boolean;
|
||||
settingsHost: string;
|
||||
@@ -178,7 +170,6 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
showAmazonPayPersonalBind: false,
|
||||
proxyStatus: 'idle',
|
||||
tokenAutoRebind: false,
|
||||
tokenAutoRebindDebug: false,
|
||||
showServerSettings: false,
|
||||
settingsHost: '',
|
||||
settingsPort: '',
|
||||
@@ -200,11 +191,8 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
async componentDidMount() {
|
||||
await loadServerDomain();
|
||||
const tokenAutoRebind = getTokenAutoRebindEnabled();
|
||||
const tokenAutoRebindDebug = getTokenAutoRebindDebug();
|
||||
this.setState({ tokenAutoRebind, tokenAutoRebindDebug });
|
||||
this.setState({ tokenAutoRebind });
|
||||
proxyBackgroundService.setTokenAutoRebindEnabled(tokenAutoRebind);
|
||||
proxyBackgroundService.setTokenAutoRebindDebugLog(tokenAutoRebindDebug);
|
||||
await this.setupPermissions();
|
||||
|
||||
const doLogin = () => {
|
||||
Api.instance.login('test123', '123456').then(async () => {
|
||||
@@ -221,7 +209,6 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
|
||||
componentWillUnmount() {
|
||||
this.stopProxyClient();
|
||||
stopSmsListener();
|
||||
this.appStateSubscription?.remove();
|
||||
}
|
||||
|
||||
@@ -229,14 +216,17 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
if (nextAppState === 'active') this.fetchWallets();
|
||||
};
|
||||
|
||||
async setupPermissions() {
|
||||
const hasSms = await checkSmsPermission();
|
||||
if (!hasSms) await requestSmsPermission();
|
||||
startSmsListener();
|
||||
onSmsMessage((msg: SmsMessage) => {
|
||||
console.log('[SMS]', msg.address, msg.body);
|
||||
});
|
||||
}
|
||||
buildTokenAutoRebindDeps = (): TokenAutoRebindDeps => ({
|
||||
listWallets: () => Api.instance.listWallets(),
|
||||
register: (_wallet, walletType: WalletType, params: Record<string, unknown>) =>
|
||||
Api.instance.register(walletType, params),
|
||||
getUserToken: () => Api.instance.getUserToken(),
|
||||
onRebound: () => this.fetchWallets(),
|
||||
isActive: async (w) => w.status === 'ACTIVE' || w.otpMode === true,
|
||||
log: this.state.tokenAutoRebind
|
||||
? (...args: unknown[]) => console.log('[TokenAutoRebind]', ...args)
|
||||
: undefined,
|
||||
});
|
||||
|
||||
async startProxyClient() {
|
||||
try {
|
||||
@@ -244,18 +234,10 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
const userId = Api.instance.getUserId();
|
||||
this.setState({ proxyStatus: 'connecting' });
|
||||
proxyBackgroundService.configureTokenAutoRebind(
|
||||
{
|
||||
listWallets: () => Api.instance.listWallets(),
|
||||
register: (_wallet, walletType: WalletType, params: Record<string, unknown>) =>
|
||||
Api.instance.register(walletType, params),
|
||||
getUserToken: () => Api.instance.getUserToken(),
|
||||
onRebound: () => this.fetchWallets(),
|
||||
isActive: async (w) => w.status === 'ACTIVE' || w.otpMode === true,
|
||||
},
|
||||
this.buildTokenAutoRebindDeps(),
|
||||
getTokenAutoRebindOptions(),
|
||||
);
|
||||
proxyBackgroundService.setTokenAutoRebindEnabled(this.state.tokenAutoRebind);
|
||||
proxyBackgroundService.setTokenAutoRebindDebugLog(this.state.tokenAutoRebindDebug);
|
||||
await proxyBackgroundService.start({
|
||||
wsUrl: Api.WS_URL, clientId: this.clientId || '', userId,
|
||||
debug: true, heartbeatInterval: 10000, reconnectInterval: 5000, reconnectMaxAttempts: Infinity,
|
||||
@@ -278,17 +260,16 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
}
|
||||
|
||||
toggleTokenAutoRebind = async (enabled: boolean) => {
|
||||
this.setState({ tokenAutoRebind: enabled });
|
||||
this.setState({ tokenAutoRebind: enabled }, () => {
|
||||
proxyBackgroundService.configureTokenAutoRebind(
|
||||
this.buildTokenAutoRebindDeps(),
|
||||
getTokenAutoRebindOptions(),
|
||||
);
|
||||
});
|
||||
await saveTokenAutoRebindEnabled(enabled);
|
||||
proxyBackgroundService.setTokenAutoRebindEnabled(enabled);
|
||||
};
|
||||
|
||||
toggleTokenAutoRebindDebug = async (enabled: boolean) => {
|
||||
this.setState({ tokenAutoRebindDebug: enabled });
|
||||
await saveTokenAutoRebindDebug(enabled);
|
||||
proxyBackgroundService.setTokenAutoRebindDebugLog(enabled);
|
||||
};
|
||||
|
||||
/** OTP / bind:API catch → { success:false, message } */
|
||||
private wrapOtpCall = async (fn: () => Promise<any>): Promise<any> => {
|
||||
try {
|
||||
@@ -1002,7 +983,7 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
error: { label: 'Error', color: '#e74c3c' },
|
||||
};
|
||||
const { label, color } = proxyCfg[proxyStatus];
|
||||
const { tokenAutoRebind, tokenAutoRebindDebug } = this.state;
|
||||
const { tokenAutoRebind } = this.state;
|
||||
|
||||
return (
|
||||
<View style={s.container}>
|
||||
@@ -1024,15 +1005,6 @@ export default class HomeScreen extends Component<any, HomeScreenState> {
|
||||
thumbColor={tokenAutoRebind ? '#3498db' : '#999'}
|
||||
/>
|
||||
</View>
|
||||
<View style={s.autoRebindRow}>
|
||||
<Text style={s.autoRebindLabel}>重绑调试日志</Text>
|
||||
<Switch
|
||||
value={tokenAutoRebindDebug}
|
||||
onValueChange={this.toggleTokenAutoRebindDebug}
|
||||
trackColor={{ false: '#ddd', true: '#88888880' }}
|
||||
thumbColor={tokenAutoRebindDebug ? '#666' : '#999'}
|
||||
/>
|
||||
</View>
|
||||
</View>
|
||||
<View style={{ flexDirection: 'row', alignItems: 'center', gap: 10 }}>
|
||||
<TouchableOpacity
|
||||
|
||||
Reference in New Issue
Block a user