HUB_STATUS: OPERATIONAL // 20_YRS_OF_KNOWLEDGE · FREE_ACCESS
Two Decades of Engineering Knowledge,Given Back. For Free.
Thousands of interview questions, real-world errors with root-cause solutions, reusable code archives, and structured learning paths — built through 20 years of actual engineering.
One lamp can light a hundred more without losing its own flame. This knowledge hub is not a product. It is not a funnel. It is a contribution — to every developer who once searched alone at 2 AM for an answer that did not exist anywhere on the internet. It exists now. Here.
— Debasis Bhattacharjee
Across 18 languages & frameworks
Real errors. Root-cause fixes.
Copy-paste ready. Production tested.
Beginner → Advanced, structured
SEARCH_INDEX: READY // FULL_TEXT · INSTANT_RESULTS
Find Anything. Instantly.
DOMAINS_MAPPED // PHP · JS · PYTHON · AI · SECURITY · ARCHITECTURE
Explore the Ecosystem
Categorized by language, role, and difficulty. From junior to architect-level. With curated model answers built from real hiring experience.
Searchable archive of real runtime errors, stack traces, and exceptions — each with root cause analysis and tested fix. Like Stack Overflow, but curated.
Reusable, production-tested code patterns across PHP, Python, JavaScript, VB.NET, SQL and more. No fluff — just working implementations.
Architecture patterns, design principles, scalability thinking, and real-world system breakdowns explained from an engineer who has built them.
Structured progression from beginner to professional — curriculum-style roadmaps with sequenced topics, milestones, and recommended resources.
Penetration testing concepts, vulnerability patterns, OWASP deep dives, and defensive coding practices drawn from real security consulting work.
INTERVIEW_PREP: ACTIVE // JUNIOR · MID · SENIOR · ARCHITECT
Questions & Answers
To implement a connection pool in Rust for PostgreSQL, I would use a crate like 'r2d2' along with 'tokio-postgres'. Key considerations include managing database connections efficiently, handling timeouts, and ensuring thread safety.
Deep Dive: A connection pool is vital for optimizing database interactions by reusing connections rather than establishing new ones for each request. Using the 'r2d2' crate allows me to create a pool of pre-initialized connections that can be shared across threads, enhancing performance. It's essential to manage the pool size based on expected load and database capabilities to avoid exhausting the available connections. Additionally, implementing timeouts ensures that requests do not hang indefinitely, which is crucial for maintaining application responsiveness.
Error handling is another critical aspect, especially for transient issues like network failures, which should be retried versus handling more severe errors gracefully. Understanding the implications of connection lifetimes in async contexts is also important, as it can lead to deadlocks or resource starvation if not managed correctly.
Real-World: In a recent project at a fintech startup, we needed to handle high-frequency trading data ingestion. We used 'r2d2' to create a connection pool for our PostgreSQL database. By configuring the pool to maintain a limited number of active connections, we significantly improved response times and reduced latency, allowing for seamless data updates. Additionally, we implemented custom logic to handle connection timeouts and retries, which proved invaluable during high-load periods when the database experienced occasional slow responses.
⚠ Common Mistakes: A common mistake when implementing a connection pool in Rust is to underestimate the pool size based on expected traffic, leading to 'connection refused' errors under load. It's crucial to benchmark and monitor usage patterns before settling on a configuration. Additionally, some developers might neglect to handle connection errors properly, opting for generic error handling rather than implementing retries for transient errors, which can lead to a poor user experience during brief outages or slowdowns. This oversight can cause applications to freeze or crash due to unresponsive database calls.
🏭 Production Scenario: In a production setting, if the application experiences a sudden spike in traffic during critical transaction processing periods, having a well-tuned connection pool can prevent downtime and maintain service availability. For instance, a banking application facing peak transaction times demands a reliable database connection strategy to ensure that customer requests are processed without delay. Poorly managed connections could lead to significant financial loss and customer dissatisfaction.
Model versioning can be implemented using tools like DVC or MLflow, which allow you to track changes in model artifacts and parameters. By tagging each model with version numbers and maintaining a metadata store, you can facilitate easy rollbacks and comparisons between model iterations.
Deep Dive: Model versioning is crucial in MLOps to maintain the integrity and traceability of machine learning models throughout their lifecycle. Tools like DVC and MLflow not only help in versioning the model files but also in capturing the parameters, metrics, and training data. This comprehensive version tracking ensures that you can easily identify the differences between versions and revert to a previous state when necessary, which is especially important in production where model performance can vary. Furthermore, it is essential to implement a consistent naming convention for your models and to maintain a well-documented changelog outlining the modifications in each version. This practice provides additional context and helps the team understand the rationale behind specific model updates or rollbacks.
Real-World: In a recent project at a tech firm, we deployed an ensemble model that initially performed well on the validation set. However, after deployment, we noticed a significant drop in performance on live data. Using MLflow, we quickly rolled back to the previous model version that had a better performance record, allowing us to mitigate potential losses while we investigated the changes in the training data that caused the issue. This use of versioning not only saved time but also maintained customer trust.
⚠ Common Mistakes: One common mistake developers make is failing to version the training datasets along with the models, leading to inconsistencies and difficulties in model performance evaluation. Additionally, some teams neglect to establish naming conventions, resulting in confusion over which model version is currently deployed. These oversights can complicate debugging and rollback processes, ultimately hindering the team's ability to maintain high-quality deployments.
🏭 Production Scenario: In a production environment, I witnessed a situation where a model update led to a drop in accuracy due to a change in the underlying data distribution. The team had not implemented proper versioning, which made it difficult to identify the exact changes that led to the performance decline. Had they employed a robust versioning system, they could have quickly identified the last stable version and reverted to it, minimizing downtime and ensuring continued service quality.
I would create a command-line tool that uses a modular structure for handling different service commands, incorporates robust error handling, and provides clear user feedback. It would utilize shell scripting for extensibility and allow for configuration via environment variables or config files for validation purposes.
Deep Dive: In designing a command-line interface for managing distributed system services, it's crucial to maintain a simple yet powerful user experience. A modular structure allows for grouping related commands together, which simplifies command discovery and usage. Error handling is vital; the CLI should gracefully manage failures by providing informative messages about what went wrong and possible resolutions. Additionally, it's essential to leverage configuration files or environment variables for setting parameters, enhancing flexibility and making it easier for users to customize behavior without altering the codebase directly. Clear documentation and help commands must be included to assist users in navigating the interface effectively.
Furthermore, implementing logging can also help in debugging and operational awareness, allowing users to trace back actions taken within the CLI. It would be wise to include support for common command patterns, such as flags for verbose or silent operation, to cater to different user needs. Ensuring the CLI adheres to Unix principles, such as composability and chaining commands, also fosters a more intuitive experience for users familiar with the Linux ecosystem.
Real-World: In a previous project, we developed a CLI tool for a microservices architecture that managed service health checks and deployments. We structured it to allow commands like 'service check' to assess the health of individual services while also enabling batch operations. The tool logged all interactions and provided an option for users to output results in JSON format for easier integration with monitoring systems. Users appreciated the clear error messages and the help command that guided them through available functions, reducing onboarding time and support requests significantly.
⚠ Common Mistakes: One common mistake is overcomplicating the command syntax, leading to usability issues. It's easy to assume users will remember complex flags or command sequences, which can deter effective use. Another mistake is insufficient error messaging; merely stating a command failed without context denies users the information they need for troubleshooting. This can result in frustration and decreased trust in the tool. Lastly, neglecting logging or feedback mechanisms fails to provide users insights into their operations, limiting their ability to diagnose issues or validate their actions.
🏭 Production Scenario: In a production environment managing a fleet of distributed services, we encountered issues where users were unable to deploy updates due to unclear error messages from our command-line tool. This led to prolonged downtime and customer dissatisfaction. By revisiting our CLI design to incorporate better error handling and logging, we were able to enhance the user's ability to understand and resolve issues swiftly, ultimately improving service reliability and user confidence in the tool.
To optimize a complex database query involving large table joins, I would first consider indexing relevant columns used in the joins. Using hash tables can also speed up lookups for keys, and partitioning large tables can reduce the amount of data scanned during the join operation.
Deep Dive: Optimizing database queries with large joins often revolves around the use of appropriate indexes and effective data structures. Indexing key columns can dramatically reduce the time complexity of lookups, transforming linear scans into logarithmic operations. Additionally, using hash tables for in-memory operations can help quickly match rows from different tables based on join keys, improving performance significantly. Partitioning tables based on certain criteria can further enhance this by ensuring that only relevant partitions of data are accessed during the join, reducing I/O operations. It's also crucial to analyze query execution plans to identify bottlenecks before implementing optimizations.
Real-World: In a recent project, we faced slow performance issues when joining a user activity log with user profiles in a data warehouse. By analyzing the query execution plan, we identified that the absence of indexes on the foreign key columns was causing full table scans. We created indexes on these columns, implemented hash joins for smaller tables, and partitioned the logs by date range. This combination reduced the query execution time from several minutes to just a few seconds, demonstrating the power of using the right data structures alongside strategic indexing.
⚠ Common Mistakes: One common mistake is neglecting to analyze the query execution plan before making optimizations, which can lead to unnecessary changes that do not address the real performance bottlenecks. Another mistake is over-indexing, where excessive indexes are created for every column, leading to increased write times and storage costs without significant read benefits. Developers sometimes overlook the potential of partitioning large tables, which can significantly improve query performance by narrowing down data scans but requires careful planning and application.
🏭 Production Scenario: Imagine a data analytics team struggling with long-running reports due to inefficient joins on large datasets. The database queries intermittently take over 10 minutes to execute, causing delays in generating business insights. As an architect, you notice that the queries lack proper indexing and analyze the execution plans to identify optimization opportunities, leading to more efficient reporting processes.
I prioritize a scalable state management solution like Vuex for large applications. Factors like team size, complexity of state, and the need for shared data across components heavily influence this choice.
Deep Dive: In large Vue.js applications, effective state management is crucial to maintain a clear flow of data and ensure that components can easily access and modify the shared state. I typically lean towards Vuex because it provides a centralized store that keeps the state predictable and allows for easier debugging. Key factors influencing my choice include the application's size and complexity, whether the application has multiple developers working on different components, and the need for state to be shared across various parts of the application. If the state is simple and contained, Vue's built-in reactive properties may suffice; however, Vuex shines when the state management demands become more intricate, needing a structured approach. Additionally, I consider the need for asynchronous actions and how they might complicate state changes, further solidifying the need for a robust solution like Vuex, perhaps with plugins for enhanced functionality.
Real-World: In a recent project, we developed an e-commerce application with multiple user roles, such as customers, sellers, and admins. Because of the complexity of interactions and the need for components to react to shared states like user authentication and product listings, we implemented Vuex. This central store allowed us to manage state transitions smoothly, with strict adherence to mutation patterns, making it easier for the team to collaborate and reducing bugs related to state inconsistency. The Vuex store also provided a space for all actions to be logged, aiding in tracking issues during development.
⚠ Common Mistakes: One common mistake developers make is underestimating the complexity of state management by opting for Vue's local state instead of a centralized store. This can lead to duplicated state across components, making the application harder to maintain and debug. Another mistake is not utilizing Vuex modules effectively for namespacing, which can result in name collisions and confusion regarding which module is responsible for what state, complicating the overall architecture of the application.
🏭 Production Scenario: In a production environment, I once observed a team struggling with state management in a large-scale project where different teams independently managed their component states. This led to significant bugs when components needed to share or synchronize data, resulting in wasted development time and increased costs. Transitioning to Vuex for centralized state management resolved these issues, leading to cleaner code and improved collaboration among teams.
To optimize inference performance for large language models, I would consider techniques such as model quantization, hardware acceleration, and batching of requests. Additionally, I would analyze the model architecture to identify opportunities for pruning or distillation.
Deep Dive: Optimizing inference performance is critical for deploying large language models, especially where low latency is required. Model quantization reduces the precision of the model weights, allowing it to consume less memory and compute resources, which can speed up inference significantly. Hardware acceleration, using GPUs or TPUs, can also reduce latency and increase throughput by parallelizing operations. Batching requests allows multiple inference requests to be processed simultaneously, further improving performance. However, it's essential to balance the trade-offs between accuracy and performance, particularly when applying techniques like pruning or distillation, which might simplify the model architecture at the risk of losing some predictive capability.
Moreover, monitoring and profiling tools can provide insights into where bottlenecks exist in the current deployment. Systems like TensorRT or ONNX Runtime can also optimize the execution of models on specific hardware, ensuring better utilization of resources. Finally, keeping an eye on updates in libraries and frameworks, such as Hugging Face Transformers, can lead to performance improvements from community contributions and optimizations over time.
Real-World: In a real-world scenario, a company deployed a large transformer-based model for customer support automation. Initial inference times averaged around 300 ms per request, which affected the user experience during peak hours. By implementing model quantization and switching to a dedicated GPU server, the company managed to reduce response times to about 50 ms. Additionally, they began batching requests from users, further optimizing the overall throughput of their service.
⚠ Common Mistakes: One common mistake is neglecting the trade-off between model accuracy and inference speed, leading to overly aggressive optimizations that degrade performance. For instance, excessive model pruning may cause significant drops in output quality. Another mistake is failing to profile the model's inference performance before deploying optimizations; without this data, teams might optimize based on assumptions rather than real bottlenecks, potentially wasting effort and resources.
🏭 Production Scenario: In a recent production scenario, our team was tasked with deploying a conversational AI solution using a large language model. During initial testing, the model's response time was unacceptable for real-time user interactions. We needed to implement various optimization strategies to ensure a smooth user experience, making it essential to fully understand and utilize inference optimization techniques effectively.
MySQL handles transactions using the ACID properties, ensuring reliability through atomicity, consistency, isolation, and durability. InnoDB supports transactions with full ACID compliance, while MyISAM does not support transactions at all, focusing instead on fast reads and simple locking mechanisms.
Deep Dive: Transactions in MySQL are critical for maintaining data integrity, especially in applications with concurrent users. InnoDB implements row-level locking and supports transactions, allowing multiple users to read and write data simultaneously without causing inconsistencies. It ensures ACID compliance by using mechanisms such as the undo log for atomicity, preserving the last consistent state in case of a failure. Additionally, InnoDB uses multiversion concurrency control (MVCC), which enhances performance by allowing readers to access data without being blocked by writers. On the other hand, MyISAM offers table-level locking which can lead to significant bottlenecks in a write-heavy environment. It does not support transactions, meaning developers must handle data consistency at the application level, exposing them to risks like lost updates or inconsistent states if not managed carefully. This foundational difference can significantly influence the architecture of applications using MySQL.
Real-World: In a high-traffic e-commerce platform, we chose InnoDB as the storage engine for our transactions related to order processing. This decision allowed multiple users to add items to their carts and complete purchases simultaneously without any data loss or corruption. The transaction support ensured that if any part of the order process failed, the entire transaction would roll back, maintaining data integrity and providing a seamless user experience during peak shopping hours.
⚠ Common Mistakes: A common mistake is misconfiguring the storage engine for the application's needs, often opting for MyISAM due to its perceived speed for read-heavy applications without considering the lack of transaction support. This can lead to data corruption issues under concurrent write operations. Another mistake is relying solely on application-level checks for data consistency, which can be brittle and error-prone, especially in complex systems where multiple operations depend on one another.
🏭 Production Scenario: In a production environment where a financial application tracks transactions in real-time, understanding transaction management is critical. Using InnoDB allows for secure updates and rollbacks, especially during inter-bank transfers where accuracy and reliability are non-negotiable. Any failure in transaction handling can lead to severe financial discrepancies.
I focus on modularizing styles, using mixins effectively, and minimizing nesting. Additionally, I leverage the @use and @forward directives for better module loading, and I implement selective loading to ensure only necessary styles are applied.
Deep Dive: Optimizing large SCSS files involves both structural changes and strategic implementation. Modularization allows for clear separation of styles, which aids in maintaining and compiling only what is necessary. Effective use of mixins can reduce code duplication and enhance maintainability, while minimizing nesting prevents excessive specificity that can lead to bloated CSS. Furthermore, the introduction of the @use and @forward directives streamlines the way styles are imported and shared between files, reducing the overall compile time. Using selective loading, such as media queries and conditionally loaded styles, ensures that higher-performance assessments during rendering are met since only the required CSS is included in final bundle outputs.
Another important aspect is the use of tools like PostCSS and Autoprefixer, which can further enhance your stylesheets by processing them to remove unused styles and adding vendor prefixes automatically. Keeping a sharp eye on CSS specificity, and ensuring that styles are not overly complex can drastically improve performance, especially for large applications that require quick loading times. Regularly auditing compiled CSS can also help catch performance issues early in the development cycle.
Real-World: In a recent project involving a large e-commerce platform, we had a massive SCSS codebase that was causing slow rendering on mobile devices. By refactoring the SCSS into smaller, more manageable components and employing the @use directive, we reduced the compile time by 40%. Additionally, we analyzed our final CSS output, removing unused styles and applying selective loading techniques, which led to improved performance benchmarks across various devices.
⚠ Common Mistakes: Many developers overlook the importance of maintaining a flat structure in SCSS files, leading to deep nesting that complicates specificity and generates excessive CSS output. This mistake can lead to slow rendering and maintenance difficulties. Another common error is the improper use of mixins, where developers create overly complex mixins that are not reused efficiently, resulting in duplicated styles in the final CSS. It's important to balance reusability with simplicity to ensure optimal performance.
🏭 Production Scenario: In one instance, our team faced a significant slowdown in an application's load time attributed to an increasingly complex SCSS structure. This situation required immediate attention as the application's performance directly impacted user experience. We had to refactor the codebase, implement optimizations, and ensure that the changes were well-tested before deployment to maintain our customer satisfaction metrics.
The API should follow the REST or gRPC protocol, support asynchronous requests, and use a load balancer to distribute incoming traffic. Caching predictions for frequently requested data can also improve response times and reduce load on the model.
Deep Dive: Designing an API for real-time predictions from a machine learning model requires careful consideration of several factors. First, you need to choose between REST and gRPC based on your use case; gRPC is often better for high-throughput applications due to its binary format and support for streaming. Utilizing asynchronous processing helps manage latency by allowing clients to send multiple requests without waiting for individual responses. Scalability can be achieved by deploying multiple instances of the model behind a load balancer, which distributes requests evenly. Additionally, caching mechanisms can store previous predictions for re-use, significantly reducing the response time for repeated queries while minimizing the load on the model itself. It's critical to incorporate monitoring for performance metrics and error rates, assisting in real-time decision-making for scaling resources dynamically.
Real-World: In a real-world scenario, a financial services company might require an API to provide credit scoring predictions in real-time during loan application processing. By implementing a gRPC-based API, they could handle high volumes of requests efficiently. The company might also use a caching layer to quickly respond to applications for similar credit profiles, enabling faster decision-making and enhancing customer satisfaction. The load balancer ensures that if one instance of the scoring model becomes a bottleneck, traffic is seamlessly rerouted, maintaining the necessary performance levels.
⚠ Common Mistakes: One common mistake is neglecting the need for model versioning, which can lead to inconsistencies in predictions if multiple versions of a model are deployed without clear management. Another frequent pitfall is underestimating the importance of monitoring and logging; without these, it’s challenging to detect performance issues or model drift that can affect accuracy over time. Lastly, many developers assume that synchronous calls are sufficient, but this can lead to performance bottlenecks, especially under high load, impacting the user experience.
🏭 Production Scenario: In a production environment at a tech company focused on e-commerce, we faced challenges with our recommendation engine API when traffic spiked during holiday sales. The existing synchronous API couldn't handle the load, causing significant delays in response times. By redesigning the API with gRPC, implementing asynchronous processing, and optimizing the caching strategy, we improved our response times and ensured a smoother experience for users, ultimately boosting sales during peak periods.
CSS preprocessors like SASS and LESS enhance productivity and maintainability in styling by allowing variables, nesting, and mixins. I would use them in larger projects where stylesheets become complex, as they make the code modular and easier to manage.
Deep Dive: CSS preprocessors like SASS and LESS introduce powerful features that streamline CSS development. They allow for the use of variables, which can store color values, font sizes, and other repetitive values, promoting consistency across the stylesheet. Nesting enables developers to write CSS rules in a hierarchy that mirrors the HTML structure, making the interface more readable and logical. Mixins allow for reusability of CSS declarations, which can simplify maintenance and reduce repetition. However, it's important to consider the project's scale; for smaller projects, the added complexity may not be justified. Additionally, if not managed properly, nested styles may lead to specificity issues or overly complex rules that can hinder performance and understanding.
Real-World: In a recent project for a retail website, we used SASS to manage our styles. The site had multiple themes, so we defined color variables for primary and secondary colors. This allowed our designers to quickly adjust the theme colors without having to sift through multiple stylesheets. We also employed mixins for reusable button styles, ensuring consistency across call-to-action buttons throughout the site. By using these features, we reduced the time spent on CSS management and streamlined updates for both the design team and developers.
⚠ Common Mistakes: One common mistake developers make is over-nesting their styles, which can lead to deeply nested selectors that become hard to read and maintain. This often results in increased specificity issues that can be challenging to debug. Another mistake is failing to properly organize variables and mixins, leading to a chaotic environment where developers struggle to find or remember where certain styles are defined. This can undermine the intended efficiency of using a preprocessor.
🏭 Production Scenario: In a large-scale web application project, the team faced challenges with CSS bloat and unmanageable stylesheets. By incorporating SASS, they were able to modularize their CSS, breaking it down into components that could be updated independently. This became especially important as the project grew and more developers joined the team, leading to fewer conflicts and improved collaboration on styling.
Showing 10 of 1774 questions
DEBUG_ARCHIVE: LIVE // REAL_ERRORS · ANNOTATED_FIXES
Real Errors. Root-Cause Fixes.
Undefined variable: $conn — PDO connection not persisted across scope
Connection object passed by value. Fix: pass by reference or use dependency injection through constructor.
Cannot read properties of undefined — React state not yet populated on first render
State initialized as undefined, not empty array. Fix: initialize with useState([]) and guard with optional chaining.
Foreign key constraint fails on INSERT — parent row not found in referenced table
Insertion order violation. Fix: insert parent record first, or disable FK checks during bulk migration with SET FOREIGN_KEY_CHECKS=0.
ModuleNotFoundError in virtual environment — pip installed globally but not inside venv
Package installed to system Python, not active venv. Fix: activate venv first, then pip install. Verify with which python.
NullReferenceException on DataGridView load — DataSource bound before data fetched
Binding fires before async fetch completes. Fix: await the data load, then set DataSource. Use BindingSource for dynamic updates.
White Screen of Death after plugin activation — memory limit exhausted on init hook
Plugin loading heavy library on every request. Fix: lazy-load on relevant admin pages only. Increase WP_MEMORY_LIMIT in wp-config as temporary measure.
Copy. Adapt. Ship.
Singleton Database Connection
Thread-safe PDO connection with single instance guarantee. Works with MySQL, PostgreSQL, SQLite.
Rate-Limited API Client
Async HTTP client with automatic retry, exponential backoff, and per-domain rate limiting.
Recursive CTE Hierarchy
Self-referencing table traversal for category trees, org charts, and menu structures using Common Table Expressions.
Custom useDebounce Hook
React hook for debouncing search inputs, form fields, and resize events. Prevents excessive API calls.
LEARNING_PATHS: READY // 4_TRACKS · STRUCTURED · MENTOR_GUIDED
Learning Paths
PHP Developer: Zero to Production
BeginnerFrom syntax fundamentals to building RESTful APIs and WordPress plugins. Designed for complete beginners with no prior programming background.
Full-Stack JavaScript: React + Node
Mid-LevelModern full-stack development with React, Node.js, Express, and PostgreSQL. Includes deployment, auth, and real project builds.
Software Architecture Mastery
AdvancedDesign patterns, SOLID principles, microservices, event-driven architecture, and real-world system design interview preparation.
AI Integration for Developers
Mid-LevelPractical AI integration using Claude API, OpenAI, and MCP. Build real AI-powered applications, tools, and automation workflows.
"The best engineering knowledge is not found in textbooks — it is extracted from late nights, broken builds, angry clients, and the stubborn refusal to stop until the problem is solved."
— Debasis Bhattacharjee · Software Architect · 20 Years in Production
ARCHIVE_GROWING // CONTRIBUTIONS_OPEN · LIVING_DOCUMENT
This Is a Living Archive. Not a Static Library.
Every week, new errors are documented, new interview patterns are added, and new solutions are tested in production. The knowledge hub grows because real problems keep appearing — and every answer earns its place here by actually working.
If you found a fix that saved your project, or spotted an answer that could be better — the door is always open. This ecosystem belongs to everyone who uses it.
Knowledge is Free.
Mentorship is Personal.
The hub is open to everyone — but if you need structured guidance, 1-on-1 mentorship, or corporate training, that's a different conversation. Let's have it.
hello@debasisbhattacharjee.com · +91 8777088548 · Mon–Fri, 9AM–6PM IST