From 9d070afa3d44b5e3d82804bfe9ef4bd028163f37 Mon Sep 17 00:00:00 2001 From: Rahul Rudragoudar Date: Tue, 26 Mar 2019 18:43:08 +0530 Subject: [PATCH 1/4] Add .db --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index f8da9a4..7972b04 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,7 @@ *.class *.log *.png +*.db /bin/ /project/target/ /target/ From 8e99f2713d383405b21a6cd4dac0ee8e0fa590d4 Mon Sep 17 00:00:00 2001 From: Rahul Rudragoudar Date: Tue, 26 Mar 2019 18:44:31 +0530 Subject: [PATCH 2/4] Add method to choose random captcha --- src/main/scala/lc/Main.scala | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/main/scala/lc/Main.scala b/src/main/scala/lc/Main.scala index bae01a4..98dc2dd 100644 --- a/src/main/scala/lc/Main.scala +++ b/src/main/scala/lc/Main.scala @@ -26,11 +26,18 @@ class Captcha { val selectPstmt: PreparedStatement = con.prepareStatement("SELECT secret, provider FROM challenge WHERE token = ?") val imagePstmt: PreparedStatement = con.prepareStatement("SELECT image FROM challenge WHERE token = ?") + val filters = Map("FilterChallenge" -> new FilterChallenge, "FontFunCaptcha" -> new FontFunCaptcha, "GifCaptcha" -> new GifCaptcha, - "ShadowTextCaptcha" -> new ShadowTextCaptcha - ) + "ShadowTextCaptcha" -> new ShadowTextCaptcha) + + def getProvider(): String = { + val random = new scala.util.Random + val keys = filters.keys + val providerMap = keys.toVector(random.nextInt(keys.size)) + providerMap + } def getCaptcha(id: Id): Array[Byte] = { imagePstmt.setString(1, id.id) @@ -45,7 +52,7 @@ class Captcha { def getChallenge(param: Parameters): Id = { //TODO: eval params to choose a provider - val providerMap = "GifCaptcha" + val providerMap = getProvider() val provider = filters(providerMap) val challenge = provider.returnChallenge() val blob = new ByteArrayInputStream(challenge.content) @@ -63,7 +70,7 @@ class Captcha { } val task = new Runnable { - val providerMap = "FilterChallenge" + val providerMap = getProvider() val provider = filters(providerMap) def run(): Unit = { val challenge = provider.returnChallenge() From e18354c259532fa55b155945d4c9e8ab21f9bc4c Mon Sep 17 00:00:00 2001 From: Rahul Rudragoudar Date: Tue, 26 Mar 2019 23:19:01 +0530 Subject: [PATCH 3/4] Add LabelCaptcha plugin Signed-off-by: Rahul Rudragoudar --- src/main/scala/lc/LabelCaptcha.scala | 80 ++++++++++++++++++++++++++++ src/main/scala/lc/Main.scala | 4 +- 2 files changed, 82 insertions(+), 2 deletions(-) create mode 100644 src/main/scala/lc/LabelCaptcha.scala diff --git a/src/main/scala/lc/LabelCaptcha.scala b/src/main/scala/lc/LabelCaptcha.scala new file mode 100644 index 0000000..664e2d5 --- /dev/null +++ b/src/main/scala/lc/LabelCaptcha.scala @@ -0,0 +1,80 @@ +package lc + +import java.io.File +import java.io.ByteArrayOutputStream +import javax.imageio.ImageIO +import scala.collection.mutable.Map +import java.nio.file.{Files,Path,StandardCopyOption} +import java.awt.image.BufferedImage +import java.awt.{Graphics2D,Color} + +class LabelCaptcha extends ChallengeProvider { + var knownFiles = new File("known").list.toList + var unknownFiles = new File("unknown").list.toList + var tokenImagePair = Map[String, ImagePair]() + var unknownAnswers = Map[String, Map[String, Int]]() + var total = Map[String, Int]() + for(file <- unknownFiles) { + unknownAnswers += file -> Map[String, Int]() + total += file -> 0 + } + def getId = "LabelCaptcha" + def returnChallenge(): Challenge = synchronized { + val r = scala.util.Random.nextInt(knownFiles.length) + val s = scala.util.Random.nextInt(unknownFiles.length) + val knownImageFile = knownFiles(r) + val unknownImageFile = unknownFiles(s) + val ip = new ImagePair(knownImageFile, unknownImageFile) + val token = scala.util.Random.nextInt(10000).toString + tokenImagePair += (token -> ip) + var knownImage = ImageIO.read(new File("known/"+knownImageFile)) + var unknownImage = ImageIO.read(new File("unknown/"+unknownImageFile)) + val width = knownImage.getWidth()+unknownImage.getWidth() + val height = List(knownImage.getHeight(), unknownImage.getHeight()).max + val imageType = knownImage.getType() + val finalImage = new BufferedImage(width, height, imageType) + val g = finalImage.createGraphics() + g.setColor(Color.WHITE) + g.fillRect(0, 0, finalImage.getWidth(), finalImage.getHeight()) + g.drawImage(knownImage, null, 0, 0) + g.drawImage(unknownImage, null, knownImage.getWidth(), 0) + g.dispose() + val baos = new ByteArrayOutputStream() + ImageIO.write(finalImage,"png",baos) + new Challenge(baos.toByteArray(), "image/png", token) + } + def checkAnswer(token: String, input: String): Boolean = synchronized { + val imagePair = tokenImagePair(token) + val expectedAnswer = imagePair.known.split('.')(0) + val userAnswer = input.split(' ') + println(userAnswer) + if(userAnswer(0)==expectedAnswer) { + println("Entered if userAnswer(0)") + val unknownFile = tokenImagePair(token).unknown + if((unknownAnswers(unknownFile)).contains(userAnswer(1))) { + println("Enterd 2 if") + unknownAnswers(unknownFile)(userAnswer(1)) += 1 + total(unknownFile) += 1 + } else { + println("Enter else") + unknownAnswers(unknownFile)+=(userAnswer(1)) -> 1 + total(unknownFile) += 1 + } + if(total(unknownFile)>=3) { + if((unknownAnswers(unknownFile)(userAnswer(1))/total(unknownFile))>=0.9) { + unknownAnswers -= unknownFile + Files.move(new File("unknown/"+unknownFile).toPath, new File("known/"+userAnswer(1)+".png").toPath, StandardCopyOption.REPLACE_EXISTING) + knownFiles = new File("known").list.toList + unknownFiles = new File("unknown").list.toList + } + } + println("ret true") + true + } else { + println("ret false") + false + } + } +} + +class ImagePair(val known: String, val unknown: String) \ No newline at end of file diff --git a/src/main/scala/lc/Main.scala b/src/main/scala/lc/Main.scala index 98dc2dd..e09fad9 100644 --- a/src/main/scala/lc/Main.scala +++ b/src/main/scala/lc/Main.scala @@ -30,7 +30,8 @@ class Captcha { val filters = Map("FilterChallenge" -> new FilterChallenge, "FontFunCaptcha" -> new FontFunCaptcha, "GifCaptcha" -> new GifCaptcha, - "ShadowTextCaptcha" -> new ShadowTextCaptcha) + "ShadowTextCaptcha" -> new ShadowTextCaptcha, + "LabelCaptcha" -> new LabelCaptcha) def getProvider(): String = { val random = new scala.util.Random @@ -58,7 +59,6 @@ class Captcha { val blob = new ByteArrayInputStream(challenge.content) val token = scala.util.Random.nextInt(10000).toString val id = Id(token) - print("Successfull") insertPstmt.setString(1, token) insertPstmt.setString(2, provider.getId) insertPstmt.setString(3, challenge.secret) From 4c0d83280307f011e937146812f6a96e703d4f5d Mon Sep 17 00:00:00 2001 From: Rahul Rudragoudar Date: Wed, 27 Mar 2019 08:20:28 +0530 Subject: [PATCH 4/4] Minor fixes Signed-off-by: Rahul Rudragoudar --- src/main/scala/lc/LabelCaptcha.scala | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/src/main/scala/lc/LabelCaptcha.scala b/src/main/scala/lc/LabelCaptcha.scala index 664e2d5..8aa08fd 100644 --- a/src/main/scala/lc/LabelCaptcha.scala +++ b/src/main/scala/lc/LabelCaptcha.scala @@ -47,16 +47,12 @@ class LabelCaptcha extends ChallengeProvider { val imagePair = tokenImagePair(token) val expectedAnswer = imagePair.known.split('.')(0) val userAnswer = input.split(' ') - println(userAnswer) if(userAnswer(0)==expectedAnswer) { - println("Entered if userAnswer(0)") val unknownFile = tokenImagePair(token).unknown if((unknownAnswers(unknownFile)).contains(userAnswer(1))) { - println("Enterd 2 if") unknownAnswers(unknownFile)(userAnswer(1)) += 1 total(unknownFile) += 1 } else { - println("Enter else") unknownAnswers(unknownFile)+=(userAnswer(1)) -> 1 total(unknownFile) += 1 } @@ -68,13 +64,11 @@ class LabelCaptcha extends ChallengeProvider { unknownFiles = new File("unknown").list.toList } } - println("ret true") true } else { - println("ret false") false } } } -class ImagePair(val known: String, val unknown: String) \ No newline at end of file +class ImagePair(val known: String, val unknown: String)