Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

✨[FEAT] #7: User domain 계층 구현 #13

Open
wants to merge 7 commits into
base: main
Choose a base branch
from
12 changes: 11 additions & 1 deletion app/src/main/java/com/umc/phrase/domain/model/User.kt
Original file line number Diff line number Diff line change
@@ -1,5 +1,15 @@
package com.umc.phrase.domain.model

data class User (
val name: String,
val id: Long,
val nickname: String,
val accountId: String,
val profileImgUrl: String?
)

data class UserDetail(
val user: User,
val followers: Long,
val followings: Long,
val comment: String?
)
Original file line number Diff line number Diff line change
@@ -1,4 +1,12 @@
package com.umc.phrase.domain.repository

import com.umc.phrase.domain.DataResource
import com.umc.phrase.domain.model.User
import kotlinx.coroutines.flow.Flow

interface UserRepository {
fun createUser(user: User): Flow<DataResource<Unit>>
fun deleteUser(id: Long): Flow<DataResource<Unit>>
fun getUser(id: Long) : Flow<DataResource<User>>
fun updateUser(user: User): Flow<DataResource<Unit>>
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package com.umc.phrase.domain.usecase.user

import com.umc.phrase.domain.DataResource
import com.umc.phrase.domain.model.User
import com.umc.phrase.domain.repository.UserRepository
import kotlinx.coroutines.flow.Flow
import javax.inject.Inject

class CreateUserUseCase @Inject constructor(
private val userRepository: UserRepository
){
operator fun invoke(user: User): Flow<DataResource<Unit>> = userRepository.createUser(user)
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
package com.umc.phrase.domain.usecase.user

import com.umc.phrase.domain.DataResource
import com.umc.phrase.domain.repository.UserRepository
import kotlinx.coroutines.flow.Flow
import javax.inject.Inject

class DeleteUserUseCase @Inject constructor(
private val userRepository: UserRepository
){
operator fun invoke(id: Long): Flow<DataResource<Unit>> = userRepository.deleteUser(id)
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,13 @@
package com.umc.phrase.domain.usecase.user

class GetUserUseCase {
import com.umc.phrase.domain.DataResource
import com.umc.phrase.domain.model.User
import com.umc.phrase.domain.repository.UserRepository
import kotlinx.coroutines.flow.Flow
import javax.inject.Inject

class GetUserUseCase @Inject constructor(
private val userRepository: UserRepository
){
operator fun invoke(id: Long): Flow<DataResource<User>> = userRepository.getUser(id)
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package com.umc.phrase.domain.usecase.user

import com.umc.phrase.domain.DataResource
import com.umc.phrase.domain.model.User
import com.umc.phrase.domain.repository.UserRepository
import kotlinx.coroutines.flow.Flow
import javax.inject.Inject

class UpdateUserUseCase @Inject constructor(
private val userRepository: UserRepository
){
operator fun invoke(user: User): Flow<DataResource<Unit>> = userRepository.updateUser(user)
}