programs/Application3.scala
author Christian Urban <urbanc@in.tum.de>
Tue, 02 Oct 2012 06:39:11 +0100
changeset 16 d627d9bc15c8
parent 13 2bd3530c30af
permissions -rw-r--r--
new slides
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
package controllers
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
import play.api._
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
import play.api.mvc._
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
import play.api.data._
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
import play.api.data.Forms._
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
import java.security.MessageDigest
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
/*
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    10
 * Application sets a cookie in plain ASCII on the
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
 * clients browser recording the visits of a page.
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    12
 *
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    13
 * The cookie data is hashed ans stored in the format:
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    14
 *
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
 * visits_counter/hashed_value 
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    16
 */
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    17
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    18
object Application extends Controller {
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    19
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    20
  //hash functions: SHA-1, SHA-256, etc
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    21
  def mk_hash(s: String) : String = {
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    22
    val hash_fun = MessageDigest.getInstance("SHA-1")
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    23
    hash_fun.digest(s.getBytes).map{ "%02x".format(_) }.mkString
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    24
  }
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    25
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    26
  //extracting from the string .../... the visits
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    27
  //value and hash
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    28
  def gt_cookie(c: Option[Cookie]) : Int = 
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
    c.map(_.value.split("/")) match {
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    30
      case Some(Array(s, h)) 
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    31
        if (s.forall(_.isDigit) && mk_hash(s) == h) => s.toInt 
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    32
      case _ => 0
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
    }
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    34
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    35
  def mk_cookie(i: Int) : Cookie = {
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    36
    val s = i.toString
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    37
    Cookie("visits", s + "/" + mk_hash(s))
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    38
  }
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    39
   
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    40
  def index = Action { request =>
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    41
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    42
    val visits_cookie = request.cookies.get("visits")
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    43
    val visits = gt_cookie(visits_cookie)
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    44
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    45
    val msg1 = "You are a valued customer who has visited this site %d times."
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    46
    val msg2 = "You have visited this site %d times."
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    47
    val msg = 
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    48
      if (visits >= 10) msg1.format(visits) else msg2.format(visits)
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    49
    
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    50
    Ok(msg).as(HTML).withCookies(mk_cookie(visits + 1))
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    51
  }     
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    52
}
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    53
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    54
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    55
2bd3530c30af added programs
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    56