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
package user.persistence.tables | |
object UserTables { | |
val driver = slick.driver.MySQLDriver | |
import driver.api._ | |
class Users(tag: Tag) extends Table[UserRegister](tag, "USERS") { | |
val username: Rep[ String ] = column[ String ]( "USERNAME", O.PrimaryKey ) |
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
trait SlickQueryOps { | |
databaseConfig: HasDatabaseConfig[ JdbcProfile ] => | |
import cats.Apply | |
import cats.std.list._ | |
import driver.api._ | |
type BooleanOp = ( Rep[ Boolean ], Rep[ Boolean ] ) => Rep[ Boolean ] | |
implicit class OptionFilter[ X, Y ]( query: Query[ X, Y, Seq ] ) { |
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
implicit class OptionFilter[ X, Y ]( query: Query[ X, Y, Seq ] ) { | |
def filteredBy[ T ]( op: Option[ T ] )( f: ( X, T ) => Column[ Option[ Boolean ] ] ): Query[ X, Y, Seq ] = { | |
op map { o => query.filter( f( _, o ) ) } getOrElse { query } | |
} | |
def foundBy[ T ]( op: Option[ T ] )( f: ( X, T ) => Column[ Option[ Boolean ] ] ): Query[ X, Y, Seq ] = { | |
op map { o => query.filter( f( _, o ) ) } getOrElse { query.take( 0 ) } | |
} | |
} |
NewerOlder