Kokodi Pogz – A Scalable Telegram Gaming Platform

Associated Link :

https://t.me/kokodigames_bot

March 1, 2025 (1mo ago)


Introduction

Kokodi Pogz is an interactive game designed as a Telegram Mini App, allowing users to play directly within the Telegram messenger environment. I led the development of this project on behalf of Kokodi Games, aiming to create a seamless gaming experience that would engage Telegram’s massive user base. The game serves as a fun, standalone experience while also complementing Kokodi Games’ broader ecosystem of titles. In this technical retrospective, I outline the key challenges I faced, the architectural solutions implemented, and the outcomes achieved in terms of performance, scalability, and user impact.


Kokodi Games and Industry Presence

Kokodi Games is a rising indie game studio known for blending innovative gameplay with cutting-edge technology. The company’s flagship title, KOKODI, is a larger-scale fantasy shooter that merges elements of RPG and battle royale genres. This main game has garnered industry attention and is slated for release on the Epic Games Store, reflecting a partnership with Epic Games and other key industry players. Within Kokodi Games’ growing ecosystem, Kokodi Pogz represents a strategic expansion — a lighter, accessible game on Telegram that introduces the Kokodi universe to a wider audience. By leveraging platforms like Telegram and collaborating with established partners such as Beam, Avalanche, Seedify, etc, Kokodi Games continues to broaden its reach and influence in the gaming community.

Project Scope and Initial Challenges

Project Scope: The Kokodi Pogz project had clear requirements from the outset:

Telegram Web App Constraints: Building on Telegram’s platform introduced unique technical constraints. Telegram Mini App run in a sandboxed in-app browser, which meant the game had to be highly optimized to load instantly within Telegram. I could not assume full browser capabilities or any access to device-specific features. Additionally, user authentication was tied to Telegram’s provided context – the app receives a signed user token from Telegram rather than using traditional login flows. This required implementing Telegram’s cryptographic verification on the server to confirm the user’s identity securely. Another challenge was adhering to Telegram’s UI and event model; for example, the web app can be closed by a simple swipe, and I needed to preserve game state and handle session restoration gracefully. All these factors demanded careful planning and technical creativity right from the start.


Technology Stack and Architectural Decisions

To meet the technical requirements and scalability challenges of Kokodi Pogz, I carefully selected and implemented a robust, modern technology stack, balancing performance, scalability, and cost-efficiency.

The core of the system was implemented as a full-stack Next.js application leveraging TypeScript. I utilized Next.js not only for the frontend interface but also to handle the primary backend logic. This unified approach simplified the codebase, enabling efficient server-side rendering, dynamic API routing, and seamless integration between frontend and backend components. For specific tasks related to Telegram bot interactions, notably payment processing, I deployed a dedicated, lightweight Express.js server. This server exclusively managed Telegram-specific functions, such as handling webhook requests triggered by the Telegram bot during payment processes, ensuring no interference with the main application flow.

To ensure robust data management and high availability, I selected MongoDB as the primary database due to its flexibility, schema-less design, and suitability for rapid development cycles. Initially, I deployed MongoDB as a sophisticated 7-server sharded cluster, consisting of two groups of replica sets, two configuration servers, and one mongos router server. This architecture was chosen to horizontally distribute database load and ensure data redundancy. However, after rigorous testing and optimization, I transitioned MongoDB from a complex sharded setup to a simpler and more efficient 3-node replica set configuration. The new replica set configuration provided sufficient resilience and failover capabilities, drastically reduced administrative complexity, and maintained performance at scale.

To mitigate performance bottlenecks and further enhance scalability, I introduced an advanced caching layer using Dragonfly, a modern in-memory caching system akin to Redis. Working closely with another developer, I integrated Dragonfly to cache frequently accessed data such as user sessions, game state, and leaderboards. An Express.js-based worker service was developed alongside this, specifically handling cache updates, synchronization, and efficient data transfer from cache to the database.

For Telegram-specific functionalities, particularly payment processing and bot interactions, I developed a dedicated Express.js backend service. This service handled Telegram’s bot-related webhooks securely and reliably, ensuring separation from the main Next.js application logic. Telegram Mini Apps require specific authentication mechanisms; thus, all user sessions were authenticated using signed tokens provided directly by Telegram, validated server-side by both the Next.js backend and the Express bot.

Additionally, to enhance application monitoring and gather actionable insights, I integrated analytics services including Cookie3 and a self-hosted Umami analytics platform, deployed directly on our own servers. These analytics services provided essential metrics on user behavior and application performance, informing further optimizations and feature development.

Finally, I developed an admin panel using Next.js with integrated Telegram authentication. This panel provided internal teams with critical tools for monitoring user statistics, managing database interactions, and interfacing with external services such as Google Cloud. This unified administrative interface streamlined operations, becoming a core tool for managing various Kokodi products.

Infrastructure and Deployment

During development and testing, I initially leveraged AWS cloud services to validate the application’s performance and to perform load testing in a convenient environment. AWS Lambda functions were used to run internal load simulations and test certain backend functions in a serverless context, which allowed us to quickly gauge how our code would perform under heavy usage without managing servers. I also used Route 53 to set up DNS and routing configurations for our staging environment. This AWS-based setup was never meant for final production, but it was invaluable for internal price and load tests – essentially experimenting with scaling the application and measuring how costs might grow on a pay-as-you-go platform. Through these tests, I discovered that while AWS provided excellent performance, the cost of running a persistent high-load application of this nature would be quite significant on AWS infrastructure. I wanted to ensure the solution would be cost-effective in the long run, so I evaluated alternatives after our testing phase.

For production deployment, I migrated the infrastructure to Hetzner, a provider offering more affordable cloud and bare-metal servers. By moving to Hetzner, I gained access to powerful hardware at a fixed monthly cost, which proved to be much more cost-efficient for our usage pattern compared to the auto-scaling cloud costs on AWS. I set up our production environment on Hetzner with multiple virtual machines: some were designated for the Next.js application servers, and others for the MongoDB database replicaset, and so on. A load balancer (software-based using Nginx/HAProxy, or a cloud load balancer service) was configured to distribute incoming requests among the Next.js application instances, ensuring no single server became a bottleneck. This separate load-balanced application tier allowed the web app to handle large numbers of simultaneous users. The database tier (the 3-node MongoDB replica set) ran on its own trio of Hetzner servers, providing resilience (if the primary went down, a secondary could take over automatically) and read scalability (the secondaries could offload read queries). I also hosted our Redis cache on the Hetzner. The network setup on Hetzner was configured with proper security groups and firewalls, and I used Hetzner Cloud’s capabilities for monitoring resource usage (CPU, memory, disk I/O) to ensure our sizing was adequate. The switch to Hetzner was justified by a significant reduction in monthly infrastructure costs while still meeting our performance requirements. In essence, after proving the system’s capabilities on AWS, I optimized for cost by running it on Hetzner, where I have full control over the machines and can fine-tune the environment.

Deployment Automation with Coolify

To manage and streamline deployments on these servers, I employed Coolify, a self-hosted deployment platform. Coolify acted as our internal PaaS (Platform as a Service), making it much easier to deploy updates to the application without manually configuring each server for every release. In practice, I containerized the Next.js application and the Express bot service using Docker. Coolify allowed us to deploy these containers to our Hetzner servers through a simple interface, handling the setup of Docker images, environment variables, and networking for each service. Essentially, Coolify is like our own private Heroku/Vercel – it automates much of the DevOps work needed to get applications running in the cloud. I could deploy to any of our servers via SSH with minimal friction, and Coolify managed the lifecycle of our applications (starting, stopping, health-checking containers, etc.) across the fleet (Coolify). This meant that scaling up the Next.js application (for example, adding another instance) or rolling out a new version was as simple as a few clicks or a Git push, and Coolify would orchestrate pulling the new code, building the Docker image, and restarting containers in a safe manner. It also provided a dashboard to monitor running services, view logs, and handle environment configuration securely. By using Coolify, I saved a lot of time on server administration and could focus more on development. It gave us confidence that deployments were repeatable and less error-prone, which is especially important when maintaining a real-time game service where downtime or glitches must be minimized.

Load Balancing and Infrastructure Optimization

To ensure reliability and ease of deployment, I containerized the entire application stack using Docker. Each component (front-end, back-end, database, cache) ran in its own Docker container, which guaranteed that the environment remained consistent across development, staging, and production. This Dockerization eliminated the “it works on my machine” problems and simplified scaling—spinning up a new application server was as straightforward as starting another container instance from the pre-built image.

I utilized a Hetzner Cloud Load Balancer in front of the Next.js servers. The load balancer was configured to perform health checks and route traffic only to healthy instances, which improved the system’s fault tolerance. If any application instance became unresponsive, the load balancer would stop sending it traffic, thereby reducing user-facing errors.

Infrastructure Optimizations Implemented:

These optimizations collectively improved the robustness of the deployment. The result was an infrastructure that could handle sudden spikes in traffic without degradation. The system was also easier to maintain: deploying updates or rolling back could be done container-by-container, with zero downtime thanks to the load balancer orchestrating traffic.

Performance Metrics and Load Testing

With the scalable infrastructure in place, I conducted extensive load testing to validate performance under high concurrency. Using JMeter, I simulated thousands of simultaneous Telegram users performing typical in-game actions (loading the app, making a purchase, etc.). These tests helped identify bottlenecks and guided further optimizations.

After iterative tuning (database query improvements, caching, and code profiling), the system achieved the following performance benchmarks:

Load Test Results (Post-Optimization)

Metric Value
Concurrent Users Simulated 10,000
Peak Throughput ~120 requests per second per API server
Average Server Response Time ~120 ms
95th Percentile Response Time 250 ms
Database CPU Utilization at peak load ~65% (down from ~90% before optimization)
Dragonfly Cache Hit Rate ~80% of applicable read requests served from cache
These metrics reflect a significant improvement after implementing caching and other optimizations. Initially, response times at high load exceeded 500 ms and the database became a major bottleneck. By introducing Dragonfly caching and fine-tuning queries, I reduced the response latency by over 50% and relieved much of the database load.

Key optimizations that led to these results:

With these improvements in place, Kokodi Pogz could comfortably handle the anticipated user load. The testing phase gave confidence that the system not only met current requirements but also could scale further with minor adjustments.

Testing and Continuous Deployment

Quality assurance and rapid iteration were facilitated by a strong testing discipline and a seamless CI/CD pipeline. I enforced a development workflow where each new feature or bug fix was validated through automated tests and then deployed to a staging environment before going live.

On the testing front, the codebase included:

For Continuous Integration and Deployment, I used GitHub for source control and implemented an automated CI/CD pipeline using GitHub Actions specifically for Docker image management:

  1. CI – Build & Test: On every push or pull request, GitHub Actions automatically installed dependencies, performed linting to ensure consistent code style, and executed unit and integration tests. Only upon successful completion of these checks would the code be allowed to merge into the main branch.

  2. Docker Image Build & Push: Upon merging changes into the production branch, GitHub Actions triggered a Docker image build using the latest application code. This image was then automatically tagged (latest) and pushed to Docker Hub, ensuring that the most current application version was always available for deployment.

After the Docker image was built and pushed, the remainder of the deployment and orchestration workflow was managed through Coolify, which streamlined the process of deploying updated containers to staging and production environments. Coolify handled tasks such as pulling the new Docker image, managing container lifecycle, and performing health checks across our Hetzner Cloud servers. This division of responsibilities simplified our DevOps workflow, enabling rapid and reliable deployment cycles with minimal manual intervention.

Telegram Mini App Integration and Bot Services

Kokodi Pogz was built as a Telegram Mini App, meaning the game’s web interface runs inside the Telegram messenger app itself. Telegram Mini Apps allow developers to create rich JavaScript-based interfaces that can be launched within Telegram chats (Telegram Mini Apps).

Notably, Mini Apps support seamless user authorization via Telegram and can leverage Telegram’s payment system and notifications through an associated bot. In our case, when a user opened the Kokodi Pogz mini app, Telegram provided our app with a signed payload containing the user’s Telegram ID and basic profile info. This authentication mechanism is built into Telegram’s Web Apps API: the Telegram client signs an init data package with the secret key of our Telegram bot, and our server verifies that signature to confirm the user’s identity (Init Data | Telegram Mini Apps). This approach ensured that we could trust the user data (Telegram ID, username, etc.) passed to our application, eliminating the need for a separate login or password — only the user’s Telegram account is needed to authenticate. On each request, the server would verify the signature by computing an HMAC with our bot’s token as the key, ensuring the request truly originated from a Telegram-authorized session.

Operating as a Telegram Mini App also imposed certain API constraints and design considerations. The web app is sandboxed within Telegram, so it cannot directly call Telegram’s internal APIs except through the allowed interfaces. For example, if the app wants to send a message to the user’s Telegram chat, it cannot simply open a socket to Telegram — instead, it must ask the companion Telegram bot to do so via the Bot API. Similarly, for security, the mini app cannot directly perform privileged actions; those actions are mediated by Telegram.

In Kokodi Pogz, the Telegram bot worked in tandem with the mini app. The bot serves multiple roles: it can send proactive messages to users (e.g., game invites or alerts), handle commands in chat, and facilitate payments. The mini app communicates with the bot’s backend (an Express service) through HTTPS requests. On the front end, I used Telegram’s Web Apps JavaScript API to interact with Telegram UI elements. When a user initiated a purchase (to buy in-game items), the mini app triggered the payment flow via a tg:// link, and Telegram coordinated the rest (payment provider selection, secure data handling). Our bot then received a webhook callback upon completion of the transaction.

To handle these payment events and other bot interactions, the project included an Express.js backend service specifically for the bot. This service received Telegram webhook updates for our bot (via a secure endpoint registered with Telegram) and processed incoming updates like user commands, callback queries, and payment confirmations. When Telegram sent an update indicating a completed purchase, the Express service verified the payment details before updating the MongoDB database (e.g., crediting the user’s account with new items or tokens). By offloading payment processing to this dedicated service, we could keep the main Next.js application focused on core gameplay logic and the user interface, while the Express service efficiently handled events, verifications, and background tasks like payments or notifications.

Integration of Telegram Stars Payment System

A standout feature of Kokodi Pogz is its integration of Telegram Stars, Telegram’s in-app virtual currency for purchasing digital goods and services. By leveraging Telegram’s familiar interface and trusted payment flow, we provided a user-friendly monetization method for the game.

Payment Flow Overview

  1. Bot Configuration: A Telegram bot was linked to the game to initiate and manage payment processes. The bot acted as the bridge between the Telegram platform and the game’s backend for all payment-related events.

  2. User Purchase Action: When a user wanted to make a purchase in the game (e.g., to buy power-ups or tokens), the front-end used Telegram’s WebApp JavaScript API to request a payment. This triggered Telegram to generate an invoice via the bot, specifying the item details and the price (in Telegram Stars).

  3. Payment Handling by Telegram: Telegram’s interface then displayed a secure payment window to the user. They could use existing Stars or acquire more through Telegram’s built-in purchase flow. Telegram or its integrated payment providers securely handled all sensitive payment details (like credit card info).

  4. Webhook Notification: Once the payment was completed, Telegram notified the bot (via a payment confirmation update). A secure endpoint in the Express API processed this webhook, verifying that the update came from Telegram (using the bot’s secret token and Telegram’s signature).

  5. Item Delivery: After successful verification, the backend granted the user the purchased items or in-game currency in MongoDB. The mini app could then reflect these changes in real time—updating the user’s inventory, balance, or in-game progress immediately.

Security Considerations

Benefits of Using Telegram Stars

By integrating Telegram Stars, Kokodi Pogz met Telegram’s guidelines for in-app purchases in mini-apps while simplifying the payment setup. Users enjoyed a swift, intuitive purchase experience—completing transactions within seconds, without leaving Telegram—and immediately saw their new items or currency. From a development standpoint, offloading the payment flow to Telegram’s secure system avoided the complexities and burdens of PCI compliance, streamlining the path to a robust and safe monetization strategy.

Admin Panel and Tools

In addition to the user-facing game app, I developed an Admin Panel as an internal tool for the Kokodi Pogz platform. This admin panel was built with Next.js as well and was deployed alongside our other services. Its primary purpose was to allow authorized team members to monitor the system, interact with the database, and manage various aspects of the platform in a friendly UI. Through the admin interface, I could observe real-time metrics such as active users, game session statistics, and server health indicators.I also built features to query and manipulate the MongoDB database from this panel — for example, searching for a specific user or adjusting in-game token balances for support purposes — all behind proper authentication and permissions. Some admin functions also integrated with Google Cloud services to support our operations. For instance, I linked certain analytics dashboards or data pipelines to Google Cloud and the admin panel provided links or triggers to those when needed. In this way, the panel served as a central hub not just for direct database inspection but also for orchestrating external tools and cloud services relevant to the project’s administration.

Security for the admin panel was critical.I implemented authentication via Telegram OAuth to ensure that only the developers or admins (who have the corresponding Telegram accounts) could log in. I chose Telegram OAuth for convenience and security — it allowed us to avoid managing separate passwords or auth databases, and since our team all had Telegram accounts, it fit naturally. Only specific Telegram user IDs (the admins) were allowed past this check. Once logged in, an admin could use the interface to perform various tasks safely. This admin tool greatly improved our ability to maintain the platform by providing visibility into the live system and the means to react quickly (for example, adjusting game parameters or fixing user issues) without needing to directly access the servers or databases via command line.

Project Management and Agile Workflow

Developing Kokodi Pogz to a successful launch required not only technical solutions but also effective project management, given the fast-paced timeline and evolving requirements. I adopted an Agile Kanban methodology to manage the project, utilizing the Kaiten app (an online Kanban board tool) integrated with the GitHub organization for source control and issue tracking.

The team did not operate in fixed-length sprints; instead, features were delivered continuously as soon as they were ready. This approach was ideal given the need to react swiftly to feedback and platform changes. Telegram’s evolving features (like the new Stars payment system, which Telegram introduced during development) meant I had to adapt quickly when it became available, and our Kanban workflow allowed us to incorporate such changes on the fly with minimal disruption.

Regular stand-up meetings (short, thrice-weekly sync-ups) were held to keep everyone aligned, though much of the coordination was handled asynchronously via Kaiten and GitHub. In summary, the combination of Kaiten for visual task management and GitHub for code management proved to be a powerful setup. It kept the project organized and transparent, enabling a successful, on-time delivery of Kokodi Pogz with minimal overhead spent on “management” and maximum focus on building the product.

Final Results and Impact

Kokodi Pogz was successfully launched as one of the first Telegram Mini App games in Kokodi Games’ portfolio, and it achieved its goals on multiple fronts. From a technical perspective, the project delivered a stable, scalable platform:

From a business and strategic standpoint, Kokodi Pogz provided Kokodi Games with a new channel for growth. The presence on Telegram – with its huge user community – acted as a marketing vehicle with organic virality (since Telegram users can easily share the game in chats and groups). It also pleased Kokodi Games’ partners; for example, demonstrating a thriving user community in Pogz helped in discussions with publishing partners like Epic Games, as it proved the appeal of the Kokodi universe beyond the core PC/console game.

The project had internal impacts as well. It served as a valuable learning and growth opportunity for the development team . By working with relatively new technologies (Telegram Mini Apps, the Telegram Stars platform, Dragonfly cache, etc.) and tackling complex integration problems, I honed my ability to rapidly adopt and master emerging tech, and helped the team do the same. The success of Kokodi Pogz has set a template for how future projects will be approached at Kokodi Games – emphasizing modular architecture, scalability from day one, and tight integration between products and the overall platform.

Conclusion

Working on Kokodi Pogz was a challenging and rewarding experience that reinforced key lessons in technical leadership and problem-solving. In this project, I had to balance fast-paced delivery (to capitalize on Telegram’s emerging platform) with sound engineering principles to ensure the product would stand the test of scale and time. Several takeaways stand out:

In conclusion, Kokodi Pogz represents a successful example of developing a complex, integrated application within the unique constraints of the Telegram platform. The project not only achieved significant user adoption and technical excellence but also provided essential insights and experiences that will inform future developments. It demonstrated how thoughtful architecture, continuous optimization, agile project management, and seamless integration with third-party APIs (such as Telegram and cloud services) can produce a robust, scalable, and engaging product.

From an engineering perspective, Kokodi Pogz provided valuable hands-on experience and deepened my understanding in several critical areas, including building and scaling full-stack applications, managing substantial user traffic, and maintaining high availability and optimal performance. Through this project, I learned to efficiently architect and optimize databases, implement advanced caching strategies, and streamline deployment workflows. The carefully designed infrastructure established a strong foundation for future expansions and enhancements. This experience reinforced the effectiveness of strategic planning, iterative development, and a commitment to delivering high-quality user experiences within emerging technological ecosystems.

🇬🇧