verification before payment and email fixes
This commit is contained in:
@@ -2,6 +2,7 @@ import 'package:logging/logging.dart';
|
||||
|
||||
import 'package:uuid/uuid.dart';
|
||||
|
||||
import 'package:pshared/api/requests/tokens/session_identifier.dart';
|
||||
import 'package:pshared/api/requests/verification/login.dart';
|
||||
import 'package:pshared/api/responses/login.dart';
|
||||
import 'package:pshared/api/responses/verification/response.dart';
|
||||
@@ -9,6 +10,8 @@ import 'package:pshared/data/mapper/account/account.dart';
|
||||
import 'package:pshared/data/mapper/session_identifier.dart';
|
||||
import 'package:pshared/models/account/account.dart';
|
||||
import 'package:pshared/models/auth/pending_login.dart';
|
||||
import 'package:pshared/models/verification/purpose.dart';
|
||||
import 'package:pshared/service/authorization/service.dart';
|
||||
import 'package:pshared/service/authorization/storage.dart';
|
||||
import 'package:pshared/service/services.dart';
|
||||
import 'package:pshared/utils/http/requests.dart';
|
||||
@@ -69,4 +72,60 @@ class VerificationService {
|
||||
await AuthorizationStorage.updateRefreshToken(loginResponse.refreshToken);
|
||||
return loginResponse.account.toDomain();
|
||||
}
|
||||
|
||||
static Future<VerificationResponse> requestPayoutCode({
|
||||
String? target,
|
||||
String? idempotencyKey,
|
||||
}) async {
|
||||
_logger.fine('Requesting payout confirmation code');
|
||||
final response = await AuthorizationService.getPOSTResponse(
|
||||
_objectType,
|
||||
'',
|
||||
LoginVerificationRequest(
|
||||
purpose: VerificationPurpose.payout,
|
||||
target: target,
|
||||
idempotencyKey: idempotencyKey ?? Uuid().v4(),
|
||||
).toJson(),
|
||||
);
|
||||
return VerificationResponse.fromJson(response);
|
||||
}
|
||||
|
||||
static Future<VerificationResponse> resendPayoutCode({
|
||||
required String idempotencyKey,
|
||||
String? target,
|
||||
}) async {
|
||||
_logger.fine('Resending payout confirmation code');
|
||||
final response = await AuthorizationService.getPOSTResponse(
|
||||
_objectType,
|
||||
'/resend',
|
||||
LoginVerificationRequest(
|
||||
purpose: VerificationPurpose.payout,
|
||||
target: target,
|
||||
idempotencyKey: idempotencyKey,
|
||||
).toJson(),
|
||||
);
|
||||
return VerificationResponse.fromJson(response);
|
||||
}
|
||||
|
||||
static Future<void> confirmPayoutCode({
|
||||
required String code,
|
||||
required String idempotencyKey,
|
||||
String? target,
|
||||
}) async {
|
||||
_logger.fine('Confirming payout code');
|
||||
await AuthorizationService.getPOSTResponse(
|
||||
_objectType,
|
||||
'/verify',
|
||||
LoginCodeVerifyicationRequest(
|
||||
purpose: VerificationPurpose.payout,
|
||||
target: target,
|
||||
idempotencyKey: idempotencyKey,
|
||||
code: code,
|
||||
sessionIdentifier: const SessionIdentifierDTO(
|
||||
clientId: '',
|
||||
deviceId: '',
|
||||
),
|
||||
).toJson(),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user