diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2012-12-10 16:35:33 +0100 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2012-12-10 16:35:33 +0100 |
commit | 3e41859789c644a59334da6a07157aa0f1e0138f (patch) | |
tree | 952a0b6506aba50bf5143bd657a2cb872fb9ad55 /src/main/scala/developerstream | |
download | developerstream-web-3e41859789c644a59334da6a07157aa0f1e0138f.tar.gz developerstream-web-3e41859789c644a59334da6a07157aa0f1e0138f.tar.bz2 developerstream-web-3e41859789c644a59334da6a07157aa0f1e0138f.tar.xz developerstream-web-3e41859789c644a59334da6a07157aa0f1e0138f.zip |
Diffstat (limited to 'src/main/scala/developerstream')
-rw-r--r-- | src/main/scala/developerstream/Db.scala | 30 | ||||
-rw-r--r-- | src/main/scala/developerstream/DeveloperStreamPlan.scala | 48 |
2 files changed, 78 insertions, 0 deletions
diff --git a/src/main/scala/developerstream/Db.scala b/src/main/scala/developerstream/Db.scala new file mode 100644 index 0000000..4ddd129 --- /dev/null +++ b/src/main/scala/developerstream/Db.scala @@ -0,0 +1,30 @@ +package developerstream + +// Import the session management, including the implicit threadLocalSession +import org.scalaquery.session._ +import org.scalaquery.session.Database.threadLocalSession +import org.joda.time.DateTime +import java.util.UUID +import java.net.URL +import java.sql.Timestamp + +// Import the query language +import org.scalaquery.ql._ + +// Import the standard SQL types +import org.scalaquery.ql.TypeMapper._ + +// Use H2Driver which implements ExtendedProfile and thus requires ExtendedTables +import org.scalaquery.ql.extended.PostgresDriver.Implicit._ +import org.scalaquery.ql.extended.{ExtendedTable => Table} + +object Db { + val JenkinsServer = new Table[(UUID, Timestamp, String, Boolean)]("jenkins_server") { + def uuid = column[UUID]("uuid", O.PrimaryKey) + def created_date = column[Timestamp]("created_date") + def url = column[String]("url") + def enabled = column[Boolean]("enabled") + // Every table needs a * projection with the same type as the table's type parameter + def * = uuid ~ created_date ~ url ~ enabled + } +} diff --git a/src/main/scala/developerstream/DeveloperStreamPlan.scala b/src/main/scala/developerstream/DeveloperStreamPlan.scala new file mode 100644 index 0000000..ff36abc --- /dev/null +++ b/src/main/scala/developerstream/DeveloperStreamPlan.scala @@ -0,0 +1,48 @@ +package developerstream + +import unfiltered.request._ +import unfiltered.response._ +import unfiltered.filter.Plan +import unfiltered.filter.Plan._ +import org.scalaquery.session.{Database, Session} +import org.scalaquery.ql.Query +import org.scalaquery.ql._ +import org.scalaquery.ql.extended.PostgresDriver.Implicit._ +import org.scalaquery.ql.extended.{ExtendedTable => Table} +import xml.Elem + +class DeveloperStreamPlan extends Plan { + + def withSession[T](f: Session => T) = Database.forURL("jdbc:postgresql://localhost/esper", user = "esper", password = "esper") withSession { session => f(session) } + + def intent: Intent = { + case Path("/") => + Ok ~> Html5(<html> + <body> + <h1>Jenkins Servers</h1> + <table> + <thead> + <tr> + <th>URL</th> + <th>Enabled</th> + </tr> + </thead> + {withSession { + implicit session => + val q = for { + server <- Db.JenkinsServer + } yield server.url ~ server.enabled + + q.list map { case (url, enabled) => <tr><td>{url}</td><td>{enabled}</td></tr> } + }} + </table> + </body> + </html>) + } + + val url = "" + val enabled = false + + def server() = + <tr><td>{url}</td><td>{enabled}</td></tr> +} |