Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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)
}