KittenRouter logo

Special thanks to Nai Jie for the logo (he also did InboxKitten logo)

Introducing KittenRouter - Serverless cousins to InboxKitten

Since we were using Cloudflare serverless kittens for our API. Why not expand this for the UI assets as well?

  • Log every web request on cloudflare (This is an enterprise only feature), helping us to track server failures.
  • Automated failover on server errors, to maintain overall site availability (High Availability!).
  • All as a reusable class module

Keeping the project small along the "do one thing and do it well" concept, the pseudo code could be summarized as below.

when receiving a request {
   for( each backend configuration ) {
      if (invalid backend configuration - wrong domain, etc) {
         continue - to next backend configuration iteration
      perform cachable request to the backend
      log request to ElasticSearch backend - or alternative log provider
         request result is valid || 
         is last configuration || 
         default backend configuration
      ) {
         return result - Ends request processing
      continue - to next backend configuration iteration

# PS: The above is conceptually the synchronous flow. In the actual
# implementation, logging should occur asynchronously without blocking

This allows us to configure redundancies within the backend, with servers coming in first, followed by firebase as "backup".

Background context (why we made this?)

why we migrated inboxkitten

When we migrated our UI frontend from Firebase to Commons.Host (an opensource and public CDN/Static hosting providers), one of the issues we faced was random 404's in random remote locations. Like Russia - possibly due to the lack of servers there.

Commonshost Global Map, server locations at point of writing

And because we are supporters of the growing πŸ‡ΈπŸ‡¬ Commons Host project, we decided to stand by them together, instead of ditching them for alternatives.

We wanted a better way to debug such issues while improving the overall reliability of our service.

Side note to any big-brother authorities, we only track static assets loading with IP address masking on No logging is done on the API. So yea, do not bother asking me for such data.

Elasticsearch Monitoring: Commons Host

What's awesome, is using the logging done by KittenRouter, of our commons host deployment, we can start having hard data on its status.

HTTP code logging

78 errors out of 12,069 requests ~ 0.65% failure rate

Is that currently in such a setup, we have 99.35% of our traffic routed through the free public servers of

And for the remaining 0.65% of request which fails, They automatically fall back onto firebase infrastructure, under its free tier.

While it's not yet 9 nines, considering that these servers and cloudflare servers are scattered around the world. It's well within the 98% of real world user metrics of most CDNs

Commons host dashboard

Furthermore, with the header information provided, we can keep track of the error rate on a per server basis. And with the KittenRouter setup on Cloudflare, you can configure such monitoring for any existing site without application code change.

We have since provided the team access to the above elasticsearch cluster for extracting useful data on their infrastructure under real user load.

Clarification notes, for privacy reasons, do not perform such level of logging on their systems for sites hosted on their platform.

The intention here for us at Uilicious, is to provide them with useful real-world usage metrics of their servers, and effectively exempting our website,, from such privacy protection, to help them improve their service.

Elasticsearch Monitoring: InboxKitten

KittenRouter world map

Finally, we are able to easily use cloudflare country codes to help us keep track of our Kitten world domination map - live!. Meow-hahaha!

Greenland, and Madagascar - I got my plague inc InboxKitten eyes set on you!

Cool! Where can I get the code

For deployment and configuration details...

Kitten Router Github

or alternatively NPM

That's cool, but Why do I even need Inboxkitten disposable email for again?

One of the key use cases currently, and why we built this project, is to perform email validations as part of our automated test scripts. Such as the following...

// Lets goto inbox kitten
I.see("Open-Source Disposable Email");

// Go to a random inbox inbox 
I.fill("email",;"Get Mail Nyow!");

// Check that its empty
I.see("There for no messages for this kitten :(");

// Testing for regular email
// (sent using a jenkins perodic build)
I.see("Open-Source Disposable Email");
I.fill("email", "ik-reciever-f7s1g28");"Get Mail Nyow!");

// See an email we expect, nyow
I.see("Testing inboxkitten subject");

With sharable test results such as

uilicious demo

Catfeeding: Uilicious testing inboxkittens XD

Plus it's simple, cool, and fun to tinker around with.

What's next for KittenRouter?

Github roadmap

Let's see where this InboxKitten journey goes next... Till then we will be taking a cat nap!

Cat sleeping

Happy Shipping πŸ––πŸΌπŸš€

This article is mirrored on
For comments and discussion please do so on instead