Last active
March 25, 2019 05:36
-
-
Save dvliman/1e4a4d5d9a36e64a63727ba4636fbd8a to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// src/main/kotlin/com/dvliman/demo/user/UserRepo.kt | |
package com.dvliman.demo.user | |
import org.davidmoten.rx.jdbc.Database | |
import org.davidmoten.rx.jdbc.Parameter | |
import org.springframework.stereotype.Component | |
import reactor.core.publisher.Mono | |
import reactor.core.publisher.Flux | |
import reactor.core.publisher.toFlux | |
import reactor.core.publisher.toMono | |
import java.sql.ResultSet | |
interface UserRepo { | |
fun createUser(req: CreateUserRequest): Mono<Int> | |
fun fetchUser(req: FetchUserRequest): Mono<User> | |
fun allUsers(): Flux<User> | |
} | |
@Component | |
class UserRepoImpl(val db: Database): UserRepo { | |
internal fun toParameters(req: CreateUserRequest): List<Parameter> = listOf( | |
Parameter.create("name", req.name), | |
Parameter.create("email", req.email)) | |
internal fun toUser(rs: ResultSet) = User( | |
user_id = rs.getInt("user_id"), | |
name = rs.getString("name"), | |
email = rs.getString("email")) | |
override fun createUser(req: CreateUserRequest): Mono<Int> = db | |
.update("INSERT INTO users (name, email) VALUES (:name, :email)") | |
.parameters(toParameters(req)) | |
.returnGeneratedKeys() | |
.getAs(Int::class.java) | |
.toMono() | |
override fun fetchUser(req: FetchUserRequest): Mono<User> = db | |
.select("SELECT user_id, name, email FROM users WHERE user_id = ${req.user_id}") | |
.get { rs -> toUser(rs) } | |
.toMono() | |
override fun allUsers(): Flux<User> = db | |
.select("SELECT user_id, name, email FROM users") | |
.get { rs -> toUser(rs) } | |
.toFlux() | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment