To solve the problem you would usually write a complicated user-based authentication system. Slightly an overkill, if you don’t need different users accessing your program at all. My idea was more that the user has to add an URL parameter with a secret key, the first time the application is called. For later requests the key would just be stored in the session object.
That way you basically access the program via the following URL:
instead of just using:
The solution is quite simple. You just have to add a Filter that is checking every request. If the desired URL parameter is passed the request will be processed as usual. If not, we just log the potential threat and return a 404 (IMHO way better than returning a 401 and motivate the intruder that way to hack your site).
Let’s have a look at the following object called
Don’t blame me if the code above is not ideal – it’s not only my first program using Play but also using Scala.
To activate the filter, you have to enhance the
Global object (store it in the default package):
object Global extends WithFilters(AuthFilter)
You may wonder about the method
validSession in the
AuthFilter. It’s purpose is to add a valid token in your unit tests. Here’s an example with a FakeRequest to /:
Have fun hiding your applications! Don’t forget that the secret key is transferred unencrypted. So if you need some extra security, add SSL. Unfortunately this cost something on Cloudbees….