feat:auth repository done
This commit is contained in:
@@ -14,6 +14,7 @@ import 'package:get_it/get_it.dart' as _i174;
|
||||
import 'package:injectable/injectable.dart' as _i526;
|
||||
|
||||
import '../../feature/auth/data/datasource/auth_datasource.dart' as _i246;
|
||||
import '../../feature/auth/data/repository/auth_repository_impl.dart' as _i648;
|
||||
import '../../feature/auth/domain/repository/auth_repository.dart' as _i884;
|
||||
import '../../feature/auth/domain/usecases/login_usecase.dart' as _i241;
|
||||
import '../../feature/auth/presentation/blocs/login_bloc/login_bloc.dart'
|
||||
@@ -62,7 +63,7 @@ extension GetItInjectableX on _i174.GetIt {
|
||||
() => _i246.AuthDatasourceImpl(gh<_i354.RequestHandlerService>()),
|
||||
);
|
||||
gh.lazySingleton<_i884.AuthRepository>(
|
||||
() => _i884.AuthRepositoryImpl(
|
||||
() => _i648.AuthRepositoryImpl(
|
||||
gh<_i354.RequestHandlerService>(),
|
||||
gh<_i246.AuthDatasource>(),
|
||||
),
|
||||
|
||||
90
lib/feature/auth/data/repository/auth_repository_impl.dart
Normal file
90
lib/feature/auth/data/repository/auth_repository_impl.dart
Normal file
@@ -0,0 +1,90 @@
|
||||
import 'package:dartz/dartz.dart';
|
||||
import 'package:food_delivery_client/core/services/request_handler_service.dart';
|
||||
import 'package:food_delivery_client/feature/auth/data/datasource/auth_datasource.dart';
|
||||
import 'package:food_delivery_client/feature/auth/data/models/response/login_response.dart';
|
||||
import 'package:food_delivery_client/food_delivery_client.dart';
|
||||
|
||||
import '../../domain/repository/auth_repository.dart';
|
||||
import '../../domain/usecases/register_usecase.dart';
|
||||
import '../../domain/usecases/reset_password_usecase.dart';
|
||||
import '../../domain/usecases/verify_otp_code_login_usecase.dart';
|
||||
import '../../domain/usecases/verify_phone_login_usecase.dart';
|
||||
|
||||
|
||||
@LazySingleton(as: AuthRepository)
|
||||
class AuthRepositoryImpl implements AuthRepository {
|
||||
final RequestHandlerService _requestHandlerService;
|
||||
final AuthDatasource _authDatasource;
|
||||
|
||||
AuthRepositoryImpl(this._requestHandlerService, this._authDatasource);
|
||||
|
||||
@override
|
||||
Future<Either<Failure, LoginResponseModel>> login({
|
||||
required String phoneNumber,
|
||||
required String password,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () async {
|
||||
return _authDatasource.login(
|
||||
phoneNumber: phoneNumber,
|
||||
password: password,
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Future<Either<Failure, SuccessModel>> register({
|
||||
required RegisterParams params,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () async => _authDatasource.register(params: params),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Future<Either<Failure, SuccessModel>> resetPassword({
|
||||
required ResetPasswordParams params,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () => _authDatasource.resetPassword(params: params),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Future<Either<Failure, SuccessModel>> verifyOtpCodeRegister({
|
||||
required VerifyOtpCodeParams params,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () => _authDatasource.verifyOtpCodeRegister(params: params),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Future<Either<Failure, SuccessModel>> verifyOtpCodeResetPassword({
|
||||
required VerifyOtpCodeParams params,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () =>
|
||||
_authDatasource.verifyOtpCodeResetPassword(params: params),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Future<Either<Failure, SuccessModel>> verifyPhoneRegister({
|
||||
required VerifyPhoneNumberParams params,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () => _authDatasource.verifyPhoneRegister(params: params),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Future<Either<Failure, SuccessModel>> verifyPhoneResetPassword({
|
||||
required VerifyPhoneNumberParams params,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () => _authDatasource.verifyPhoneResetPassword(params: params),
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -4,32 +4,40 @@ import 'package:food_delivery_client/feature/auth/data/datasource/auth_datasourc
|
||||
import 'package:food_delivery_client/feature/auth/data/models/response/login_response.dart';
|
||||
import 'package:food_delivery_client/food_delivery_client.dart';
|
||||
|
||||
import '../usecases/register_usecase.dart';
|
||||
import '../usecases/reset_password_usecase.dart';
|
||||
import '../usecases/verify_otp_code_login_usecase.dart';
|
||||
import '../usecases/verify_phone_login_usecase.dart';
|
||||
|
||||
abstract class AuthRepository {
|
||||
Future<Either<Failure, LoginResponseModel>> login({
|
||||
required String phoneNumber,
|
||||
required String password,
|
||||
});
|
||||
|
||||
Future<Either<Failure, SuccessModel>> verifyPhoneResetPassword({
|
||||
required VerifyPhoneNumberParams params,
|
||||
});
|
||||
|
||||
Future<Either<Failure, SuccessModel>> verifyOtpCodeResetPassword({
|
||||
required VerifyOtpCodeParams params,
|
||||
});
|
||||
|
||||
Future<Either<Failure, SuccessModel>> resetPassword({
|
||||
required ResetPasswordParams params,
|
||||
});
|
||||
|
||||
Future<Either<Failure, SuccessModel>> verifyPhoneRegister({
|
||||
required VerifyPhoneNumberParams params,
|
||||
});
|
||||
|
||||
Future<Either<Failure, SuccessModel>> verifyOtpCodeRegister({
|
||||
required VerifyOtpCodeParams params,
|
||||
});
|
||||
|
||||
Future<Either<Failure, SuccessModel>> register({
|
||||
required RegisterParams params,
|
||||
});
|
||||
}
|
||||
|
||||
@LazySingleton(as: AuthRepository)
|
||||
class AuthRepositoryImpl implements AuthRepository {
|
||||
final RequestHandlerService _requestHandlerService;
|
||||
final AuthDatasource _authDatasource;
|
||||
|
||||
AuthRepositoryImpl(this._requestHandlerService, this._authDatasource);
|
||||
|
||||
@override
|
||||
Future<Either<Failure, LoginResponseModel>> login({
|
||||
required String phoneNumber,
|
||||
required String password,
|
||||
}) async {
|
||||
return _requestHandlerService.handleRequestInRepository(
|
||||
onRequest: () async {
|
||||
return _authDatasource.login(
|
||||
phoneNumber: phoneNumber,
|
||||
password: password,
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user