summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt9
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt26
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt8
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt26
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt14
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt14
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt9
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt8
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt18
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt20
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt19
-rw-r--r--app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt18
-rw-r--r--app/src/main/res/layout/fragment_login.xml2
-rw-r--r--app/src/main/res/values-es/strings.xml3
-rw-r--r--app/src/main/res/values/strings.xml3
15 files changed, 194 insertions, 3 deletions
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt
new file mode 100644
index 0000000..3f761ea
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt
@@ -0,0 +1,9 @@
+package com.frannazario.proyectoandroid.data.datasources
+
+import androidx.lifecycle.LiveData
+import com.frannazario.proyectoandroid.data.responses.LoginResponse
+import com.frannazario.proyectoandroid.data.responses.SigninResponse
+
+interface LoginDataSource {
+ fun login (email: String, password: String): LiveData<LoginResponse>
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt
new file mode 100644
index 0000000..3f86c06
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt
@@ -0,0 +1,26 @@
+package com.frannazario.proyectoandroid.data.datasources
+
+import androidx.lifecycle.LiveData
+import androidx.lifecycle.MutableLiveData
+import com.frannazario.proyectoandroid.data.responses.LoginResponse
+import com.google.firebase.auth.FirebaseAuth
+
+class LoginRemoteDataSource: LoginDataSource{
+ private val auth = FirebaseAuth.getInstance()
+
+ override fun login(email: String, password: String): LiveData<LoginResponse> {
+ val resultLiveData = MutableLiveData<LoginResponse>()
+
+ auth.signInWithEmailAndPassword(email, password)
+ .addOnCompleteListener { task ->
+ if (task.isSuccessful) {
+ val user = auth.currentUser
+ resultLiveData.value = LoginResponse.Success(user)
+ } else {
+ val error = task.exception?.message ?: "Error desconocido"
+ resultLiveData.value = LoginResponse.Error(error)
+ }
+ }
+ return resultLiveData
+ }
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt
new file mode 100644
index 0000000..5ef08f4
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt
@@ -0,0 +1,8 @@
+package com.frannazario.proyectoandroid.data.datasources
+
+import androidx.lifecycle.LiveData
+import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse
+
+interface PasswordRecoveryDataSource {
+ fun recover (email: String): LiveData<PasswordRecoveryResponse>
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt
new file mode 100644
index 0000000..08335ad
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt
@@ -0,0 +1,26 @@
+package com.frannazario.proyectoandroid.data.datasources
+
+import androidx.lifecycle.LiveData
+import androidx.lifecycle.MutableLiveData
+import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse
+import com.google.firebase.auth.FirebaseAuth
+
+class PasswordRecoveryRemoteDataSource: PasswordRecoveryDataSource {
+ private val auth = FirebaseAuth.getInstance()
+
+ override fun recover (email: String): LiveData<PasswordRecoveryResponse> {
+ val resultLiveData = MutableLiveData<PasswordRecoveryResponse>()
+
+ auth.sendPasswordResetEmail(email)
+ .addOnCompleteListener { task ->
+ if (task.isSuccessful) {
+ val user = auth.currentUser
+ resultLiveData.value = PasswordRecoveryResponse.Success(user)
+ } else {
+ val error = task.exception?.message ?: "Error desconocido"
+ resultLiveData.value = PasswordRecoveryResponse.Error(error)
+ }
+ }
+ return resultLiveData
+ }
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt
new file mode 100644
index 0000000..9532534
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt
@@ -0,0 +1,14 @@
+package com.frannazario.proyectoandroid.data.repositories
+
+import androidx.lifecycle.LiveData
+import com.frannazario.proyectoandroid.data.datasources.LoginDataSource
+import com.frannazario.proyectoandroid.data.datasources.LoginRemoteDataSource
+import com.frannazario.proyectoandroid.data.responses.LoginResponse
+
+class LoginRepository(
+ private val remoteDataSource: LoginDataSource = LoginRemoteDataSource()
+ ) {
+ fun login (email: String, password: String): LiveData<LoginResponse> {
+ return remoteDataSource.login(email, password)
+ }
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt
new file mode 100644
index 0000000..6550ae2
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt
@@ -0,0 +1,14 @@
+package com.frannazario.proyectoandroid.data.repositories
+
+import androidx.lifecycle.LiveData
+import com.frannazario.proyectoandroid.data.datasources.PasswordRecoveryDataSource
+import com.frannazario.proyectoandroid.data.datasources.PasswordRecoveryRemoteDataSource
+import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse
+
+class PasswordRecoveryRepository (
+ private val remoteDataSource: PasswordRecoveryDataSource= PasswordRecoveryRemoteDataSource()
+ ) {
+ fun recover(email: String): LiveData<PasswordRecoveryResponse> {
+ return remoteDataSource.recover(email)
+ }
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt
new file mode 100644
index 0000000..9eb5518
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt
@@ -0,0 +1,9 @@
+package com.frannazario.proyectoandroid.data.responses
+
+import com.google.firebase.auth.FirebaseUser
+
+sealed class LoginResponse {
+
+ data class Success(val user: FirebaseUser?): LoginResponse()
+ data class Error(val error: String): LoginResponse()
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt
new file mode 100644
index 0000000..98b5e39
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt
@@ -0,0 +1,8 @@
+package com.frannazario.proyectoandroid.data.responses
+
+import com.google.firebase.auth.FirebaseUser
+
+sealed class PasswordRecoveryResponse {
+ data class Success(val user: FirebaseUser?): PasswordRecoveryResponse()
+ data class Error(val error: String): PasswordRecoveryResponse()
+} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt
new file mode 100644
index 0000000..9fe0988
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt
@@ -0,0 +1,18 @@
+package com.frannazario.proyectoandroid.data.viewmodels
+
+import androidx.lifecycle.LiveData
+import androidx.lifecycle.MutableLiveData
+import androidx.lifecycle.ViewModel
+import com.frannazario.proyectoandroid.data.repositories.LoginRepository
+import com.frannazario.proyectoandroid.data.responses.LoginResponse
+
+class LoginViewModel(private val repository: LoginRepository= LoginRepository()): ViewModel() {
+ private val loginResponseLiveData = MutableLiveData<LoginResponse>()
+ fun getLoginResultLiveData(): LiveData<LoginResponse> {
+ return loginResponseLiveData
+ }
+ fun login(email: String, password: String) {
+ val response = repository.login(email, password)
+ loginResponseLiveData.postValue(response.value)
+ }
+}
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt
new file mode 100644
index 0000000..b2511a8
--- /dev/null
+++ b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt
@@ -0,0 +1,20 @@
+package com.frannazario.proyectoandroid.data.viewmodels
+
+import androidx.lifecycle.LiveData
+import androidx.lifecycle.MutableLiveData
+import androidx.lifecycle.ViewModel
+import com.frannazario.proyectoandroid.data.repositories.PasswordRecoveryRepository
+import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse
+
+class PasswordRecoveryViewModel(private val repository: PasswordRecoveryRepository = PasswordRecoveryRepository()): ViewModel() {
+ private val passwordRecoveryResponseLiveData = MutableLiveData<PasswordRecoveryResponse>()
+
+ fun getPasswordRecoveryResultLiveData(): LiveData<PasswordRecoveryResponse> {
+ return passwordRecoveryResponseLiveData
+ }
+
+ fun recover (email: String) {
+ val response = repository.recover(email)
+ passwordRecoveryResponseLiveData.postValue(response.value)
+ }
+}
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt
index fcabbe1..7167738 100644
--- a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt
+++ b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt
@@ -7,11 +7,19 @@ import android.view.ViewGroup
import androidx.fragment.app.Fragment
import androidx.navigation.fragment.findNavController
import com.frannazario.proyectoandroid.R
+import com.frannazario.proyectoandroid.data.responses.LoginResponse
+import com.frannazario.proyectoandroid.data.viewmodels.LoginViewModel
import com.frannazario.proyectoandroid.databinding.FragmentLoginBinding
class LoginFragment: Fragment() {
private lateinit var binding: FragmentLoginBinding
+ private lateinit var viewModel: LoginViewModel
+
+ override fun onCreate(savedInstanceState: Bundle?) {
+ super.onCreate(savedInstanceState)
+ viewModel = LoginViewModel()
+ }
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
@@ -26,4 +34,15 @@ class LoginFragment: Fragment() {
}
return binding.root
}
+
+
+ override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
+ super.onViewCreated(view, savedInstanceState)
+ viewModel.getLoginResultLiveData().observe(viewLifecycleOwner) { response ->
+ when (response) {
+ is LoginResponse.Success -> {}
+ is LoginResponse.Error -> {}
+ }
+ }
+ }
} \ No newline at end of file
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt
index 35b56d0..7c7d922 100644
--- a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt
+++ b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt
@@ -5,10 +5,18 @@ import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.fragment.app.Fragment
+import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse
+import com.frannazario.proyectoandroid.data.viewmodels.PasswordRecoveryViewModel
import com.frannazario.proyectoandroid.databinding.FragmentPasswordRecoveryBinding
class PasswordRecoveryFragment: Fragment() {
private lateinit var binding: FragmentPasswordRecoveryBinding
+ private lateinit var viewModel: PasswordRecoveryViewModel
+
+ override fun onCreate(savedInstanceState: Bundle?) {
+ super.onCreate(savedInstanceState)
+ viewModel = PasswordRecoveryViewModel()
+ }
override fun onCreateView(
inflater: LayoutInflater,
@@ -18,4 +26,14 @@ class PasswordRecoveryFragment: Fragment() {
binding = FragmentPasswordRecoveryBinding.inflate(inflater, container, false)
return binding.root
}
+
+ override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
+ super.onViewCreated(view, savedInstanceState)
+ viewModel.getPasswordRecoveryResultLiveData().observe(viewLifecycleOwner) { response ->
+ when (response) {
+ is PasswordRecoveryResponse.Success -> {}
+ is PasswordRecoveryResponse.Error -> {}
+ }
+ }
+ }
} \ No newline at end of file
diff --git a/app/src/main/res/layout/fragment_login.xml b/app/src/main/res/layout/fragment_login.xml
index ca2d5bc..61f0a8d 100644
--- a/app/src/main/res/layout/fragment_login.xml
+++ b/app/src/main/res/layout/fragment_login.xml
@@ -59,6 +59,6 @@
app:layout_constraintTop_toBottomOf="@id/forget_password_btn"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
- android:text="@string/signin" />
+ android:text="@string/signup" />
</androidx.constraintlayout.widget.ConstraintLayout> \ No newline at end of file
diff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml
index 3f7cc92..a4a8581 100644
--- a/app/src/main/res/values-es/strings.xml
+++ b/app/src/main/res/values-es/strings.xml
@@ -1,9 +1,10 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="field_email">Correo electronico</string>
+ <string name="field_password">Contrasena</string>
<string name="field_signin">Registro</string>
<string name="field_password">Contraseña</string>
<string name="forgot_password">Olvidé la contraseña</string>
- <string name="signin">Registrarte</string>
+ <string name="signup">Registrarte</string>
<string name="login">Acceder</string>
</resources> \ No newline at end of file
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 84a3e04..b04b94d 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -2,9 +2,10 @@
<string name="app_name" translatable="false">Proyecto android</string>
<string name="field_email">Email</string>
+ <string name="field_password">Password</string>
<string name="field_signin">Sign in</string>
<string name="field_password">Password</string>
<string name="forgot_password">Forget password</string>
- <string name="signin">Sign in</string>
+ <string name="signup">Sign Up</string>
<string name="login">Login</string>
</resources> \ No newline at end of file