fix sms otp retriver

This commit is contained in:
2026-05-31 00:05:21 +08:00
parent 80bf462d2c
commit 557931892f
6 changed files with 168 additions and 74 deletions

View File

@@ -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 / bindAPI 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