[{"data":1,"prerenderedAt":9616},["ShallowReactive",2],{"navigation":3,"/microservices-with-django/development-environment":1016,"/microservices-with-django/development-environment-surround":9611},[4,54,89,123,165,211,253,331,389,439,462,488,514,540,578,624,650,672,702,736,774,800,850,856,862,868,874,928],{"title":5,"path":6,"stem":7,"children":8},"Introduction and Foundations","/introduction-and-foundations","01.introduction-and-foundations/01.index",[9,10,14,18,22,26,30,34,38,42,46,50],{"title":5,"path":6,"stem":7},{"title":11,"path":12,"stem":13},"What is Django","/introduction-and-foundations/what-is-django","01.introduction-and-foundations/02.what-is-django",{"title":15,"path":16,"stem":17},"Key Concepts and Philosophy","/introduction-and-foundations/key-concepts-and-philosophy","01.introduction-and-foundations/03.key-concepts-and-philosophy",{"title":19,"path":20,"stem":21},"MVC vs MVT: Understanding Django's Architecture","/introduction-and-foundations/mvc-vs-mvt","01.introduction-and-foundations/04.mvc-vs-mvt",{"title":23,"path":24,"stem":25},"Project Structure Overview","/introduction-and-foundations/project-structure-overview","01.introduction-and-foundations/05.project-structure-overview",{"title":27,"path":28,"stem":29},"Installing Django","/introduction-and-foundations/installing-django","01.introduction-and-foundations/06.installing-django",{"title":31,"path":32,"stem":33},"Creating Your First Django Project","/introduction-and-foundations/creating-first-project","01.introduction-and-foundations/07.creating-first-project",{"title":35,"path":36,"stem":37},"Creating Your First Django App","/introduction-and-foundations/creating-first-app","01.introduction-and-foundations/08.creating-first-app",{"title":39,"path":40,"stem":41},"Your First Django \"Hello World\"","/introduction-and-foundations/hello-world","01.introduction-and-foundations/09.hello-world",{"title":43,"path":44,"stem":45},"Django Quick Start Guide","/introduction-and-foundations/quick-start-guide","01.introduction-and-foundations/10.quick-start-guide",{"title":47,"path":48,"stem":49},"How Django Handles Requests","/introduction-and-foundations/how-django-handles-requests","01.introduction-and-foundations/11.how-django-handles-requests",{"title":51,"path":52,"stem":53},"Django Settings","/introduction-and-foundations/django-settings","01.introduction-and-foundations/12.django-settings",{"title":55,"path":56,"stem":57,"children":58},"The Development Environment","/development-environment","02.development-environment/1.index",[59,61,65,69,73,77,81,85],{"title":60,"path":56,"stem":57},"Development Environment",{"title":62,"path":63,"stem":64},"Recommended Tooling for Django Development","/development-environment/recommended-tooling","02.development-environment/2.recommended-tooling",{"title":66,"path":67,"stem":68},"Virtual Environments","/development-environment/virtual-environments","02.development-environment/3.virtual-environments",{"title":70,"path":71,"stem":72},"Django Admin and Management Commands","/development-environment/admin-and-management-commands","02.development-environment/4.admin-and-management-commands",{"title":74,"path":75,"stem":76},"Django Project Settings","/development-environment/project-settings","02.development-environment/5.project-settings",{"title":78,"path":79,"stem":80},"Managing Django Environments: Local, Staging, and Production","/development-environment/environments-local-staging-production","02.development-environment/6.environments-local-staging-production",{"title":82,"path":83,"stem":84},"Running Django Development Server","/development-environment/running-development-server","02.development-environment/7.running-development-server",{"title":86,"path":87,"stem":88},"Working with Django Shell","/development-environment/working-with-shell","02.development-environment/8.working-with-shell",{"title":90,"path":91,"stem":92,"children":93},"Templates and Presentation Layer","/templates-and-presentation","03.templates-and-presentation/1.index",[94,95,99,103,107,111,115,119],{"title":90,"path":91,"stem":92},{"title":96,"path":97,"stem":98},"Introduction to Django Templates","/templates-and-presentation/introduction-to-templates","03.templates-and-presentation/2.introduction-to-templates",{"title":100,"path":101,"stem":102},"The Django Template Language","/templates-and-presentation/django-template-language","03.templates-and-presentation/3.django-template-language",{"title":104,"path":105,"stem":106},"Template Inheritance","/templates-and-presentation/template-inheritance","03.templates-and-presentation/4.template-inheritance",{"title":108,"path":109,"stem":110},"Built-in Template Tags and Filters","/templates-and-presentation/built-in-template-tags-and-filters","03.templates-and-presentation/5.built-in-template-tags-and-filters",{"title":112,"path":113,"stem":114},"Including Static Files","/templates-and-presentation/including-static-files","03.templates-and-presentation/6.including-static-files",{"title":116,"path":117,"stem":118},"Working with Media Files","/templates-and-presentation/working-with-media-files","03.templates-and-presentation/7.working-with-media-files",{"title":120,"path":121,"stem":122},"Using Alternative Template Engines","/templates-and-presentation/using-alternative-template-engines","03.templates-and-presentation/8.using-alternative-template-engines",{"title":124,"path":125,"stem":126,"children":127},"URLs and Views","/urls-and-views","04.urls-and-views/01.index",[128,129,133,137,141,145,149,153,157,161],{"title":124,"path":125,"stem":126},{"title":130,"path":131,"stem":132},"The URL Dispatcher","/urls-and-views/the-url-dispatcher","04.urls-and-views/02.the-url-dispatcher",{"title":134,"path":135,"stem":136},"Writing Function-Based Views","/urls-and-views/writing-function-based-views","04.urls-and-views/03.writing-function-based-views",{"title":138,"path":139,"stem":140},"View Decorators","/urls-and-views/view-decorators","04.urls-and-views/04.view-decorators",{"title":142,"path":143,"stem":144},"Rendering Responses","/urls-and-views/rendering-responses","04.urls-and-views/05.rendering-responses",{"title":146,"path":147,"stem":148},"Redirects","/urls-and-views/redirects","04.urls-and-views/06.redirects",{"title":150,"path":151,"stem":152},"Handling HTTP Methods","/urls-and-views/handling-http-methods","04.urls-and-views/07.handling-http-methods",{"title":154,"path":155,"stem":156},"Conditional View Processing","/urls-and-views/conditional-view-processing","04.urls-and-views/08.conditional-view-processing",{"title":158,"path":159,"stem":160},"File Uploads","/urls-and-views/file-uploads","04.urls-and-views/09.file-uploads",{"title":162,"path":163,"stem":164},"Using Django Shortcut Functions","/urls-and-views/using-django-shortcut-functions","04.urls-and-views/10.using-django-shortcut-functions",{"title":166,"path":167,"stem":168,"children":169},"Class Based Views","/class-based-views","05.class-based-views/01.index",[170,171,175,179,183,187,191,195,199,203,207],{"title":166,"path":167,"stem":168},{"title":172,"path":173,"stem":174},"Introduction to Class-Based Views","/class-based-views/introduction-to-class-based-views","05.class-based-views/02.introduction-to-class-based-views",{"title":176,"path":177,"stem":178},"Common Base Classes","/class-based-views/common-base-classes","05.class-based-views/03.common-base-classes",{"title":180,"path":181,"stem":182},"Built-in Generic Views","/class-based-views/built-in-generic-views","05.class-based-views/04.built-in-generic-views",{"title":184,"path":185,"stem":186},"Views for CRUD Operations","/class-based-views/views-for-crud-operations","05.class-based-views/05.views-for-crud-operations",{"title":188,"path":189,"stem":190},"Handling Forms with Class-Based Views","/class-based-views/handling-forms-with-class-based-views","05.class-based-views/06.handling-forms-with-class-based-views",{"title":192,"path":193,"stem":194},"Using Mixins","/class-based-views/using-mixins","05.class-based-views/07.using-mixins",{"title":196,"path":197,"stem":198},"URL Configuration with Class-Based Views","/class-based-views/url-configuration-with-class-based-views","05.class-based-views/08.url-configuration-with-class-based-views",{"title":200,"path":201,"stem":202},"Subclassing Generic Views","/class-based-views/subclassing-generic-views","05.class-based-views/09.subclassing-generic-views",{"title":204,"path":205,"stem":206},"Asynchronous Class-Based Views","/class-based-views/asynchronous-class-based-views","05.class-based-views/10.asynchronous-class-based-views",{"title":208,"path":209,"stem":210},"Pagination","/class-based-views/pagination","05.class-based-views/11.pagination",{"title":212,"path":213,"stem":214,"children":215},"Forms and User Input","/forms-and-user-input","06.forms-and-user-input/01.index",[216,217,221,225,229,233,237,241,245,249],{"title":212,"path":213,"stem":214},{"title":218,"path":219,"stem":220},"Understanding HTML Forms","/forms-and-user-input/understanding-html-forms","06.forms-and-user-input/02.understanding-html-forms",{"title":222,"path":223,"stem":224},"Django's Role in Form Handling","/forms-and-user-input/djangos-role-in-form-handling","06.forms-and-user-input/03.djangos-role-in-form-handling",{"title":226,"path":227,"stem":228},"Creating Forms with Forms API","/forms-and-user-input/creating-forms-with-forms-api","06.forms-and-user-input/04.creating-forms-with-forms-api",{"title":230,"path":231,"stem":232},"Form Validation","/forms-and-user-input/form-validation","06.forms-and-user-input/05.form-validation",{"title":234,"path":235,"stem":236},"Built-in Fields and Widgets","/forms-and-user-input/built-in-fields-and-widgets","06.forms-and-user-input/06.built-in-fields-and-widgets",{"title":238,"path":239,"stem":240},"Form Rendering in Templates","/forms-and-user-input/form-rendering-in-templates","06.forms-and-user-input/07.form-rendering-in-templates",{"title":242,"path":243,"stem":244},"Model Forms","/forms-and-user-input/model-forms","06.forms-and-user-input/08.model-forms",{"title":246,"path":247,"stem":248},"Advanced Form Techniques","/forms-and-user-input/advanced-form-techniques","06.forms-and-user-input/09.advanced-form-techniques",{"title":250,"path":251,"stem":252},"Security Considerations for Forms","/forms-and-user-input/security-considerations-for-forms","06.forms-and-user-input/10.security-considerations-for-forms",{"title":254,"path":255,"stem":256,"children":257},"Models and Databases","/models-and-databases","07.models-and-databases/01.index",[258,259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327],{"title":254,"path":255,"stem":256},{"title":260,"path":261,"stem":262},"Understanding Django Models","/models-and-databases/understanding-django-models","07.models-and-databases/02.understanding-django-models",{"title":264,"path":265,"stem":266},"Defining Fields","/models-and-databases/defining-fields","07.models-and-databases/03.defining-fields",{"title":268,"path":269,"stem":270},"Relationships and Foreign Keys","/models-and-databases/relationships-and-foreign-keys","07.models-and-databases/04.relationships-and-foreign-keys",{"title":272,"path":273,"stem":274},"Examples of Relationship Patterns","/models-and-databases/examples-of-relationship-patterns","07.models-and-databases/05.examples-of-relationship-patterns",{"title":276,"path":277,"stem":278},"Making Queries","/models-and-databases/making-queries","07.models-and-databases/06.making-queries",{"title":280,"path":281,"stem":282},"Filtering, Ordering, and Slicing","/models-and-databases/filtering-ordering-slicing","07.models-and-databases/07.filtering-ordering-slicing",{"title":284,"path":285,"stem":286},"Managers and QuerySets","/models-and-databases/managers-and-querysets","07.models-and-databases/08.managers-and-querysets",{"title":288,"path":289,"stem":290},"Aggregation","/models-and-databases/aggregation","07.models-and-databases/09.aggregation",{"title":292,"path":293,"stem":294},"Search","/models-and-databases/search","07.models-and-databases/10.search",{"title":296,"path":297,"stem":298},"Raw SQL Queries","/models-and-databases/raw-sql-queries","07.models-and-databases/11.raw-sql-queries",{"title":300,"path":301,"stem":302},"Transactions","/models-and-databases/transactions","07.models-and-databases/12.transactions",{"title":304,"path":305,"stem":306},"Multiple Databases","/models-and-databases/multiple-databases","07.models-and-databases/13.multiple-databases",{"title":308,"path":309,"stem":310},"Tablespaces","/models-and-databases/tablespaces","07.models-and-databases/14.tablespaces",{"title":312,"path":313,"stem":314},"Composite Primary Keys","/models-and-databases/composite-primary-keys","07.models-and-databases/15.composite-primary-keys",{"title":316,"path":317,"stem":318},"Database Instrumentation","/models-and-databases/database-instrumentation","07.models-and-databases/16.database-instrumentation",{"title":320,"path":321,"stem":322},"Database Optimization","/models-and-databases/database-optimization","07.models-and-databases/17.database-optimization",{"title":324,"path":325,"stem":326},"Fixtures","/models-and-databases/fixtures","07.models-and-databases/18.fixtures",{"title":328,"path":329,"stem":330},"Signals","/models-and-databases/signals","07.models-and-databases/19.signals",{"title":332,"path":333,"stem":334,"children":335},"Migrations","/migrations","08.migrations/01.index",[336,337,341,345,349,353,357,361,365,369,373,377,381,385],{"title":332,"path":333,"stem":334},{"title":338,"path":339,"stem":340},"How Migrations Work","/migrations/how-migrations-work","08.migrations/02.how-migrations-work",{"title":342,"path":343,"stem":344},"Management Commands","/migrations/management-commands","08.migrations/03.management-commands",{"title":346,"path":347,"stem":348},"Dependencies and Workflow","/migrations/dependencies-and-workflow","08.migrations/04.dependencies-and-workflow",{"title":350,"path":351,"stem":352},"Transaction Handling","/migrations/transaction-handling","08.migrations/05.transaction-handling",{"title":354,"path":355,"stem":356},"Adding Migrations to Apps","/migrations/adding-migrations-to-apps","08.migrations/06.adding-migrations-to-apps",{"title":358,"path":359,"stem":360},"Reversing Migrations","/migrations/reversing-migrations","08.migrations/07.reversing-migrations",{"title":362,"path":363,"stem":364},"Historical Models","/migrations/historical-models","08.migrations/08.historical-models",{"title":366,"path":367,"stem":368},"Considerations When Removing Fields","/migrations/considerations-when-removing-fields","08.migrations/09.considerations-when-removing-fields",{"title":370,"path":371,"stem":372},"Data Migrations","/migrations/data-migrations","08.migrations/10.data-migrations",{"title":374,"path":375,"stem":376},"Squashing Migrations","/migrations/squashing-migrations","08.migrations/11.squashing-migrations",{"title":378,"path":379,"stem":380},"Serializing Values","/migrations/serializing-values","08.migrations/12.serializing-values",{"title":382,"path":383,"stem":384},"Supporting Multiple Django Versions","/migrations/supporting-multiple-django-versions","08.migrations/13.supporting-multiple-django-versions",{"title":386,"path":387,"stem":388},"Django Serialization Framework","/migrations/django-serialization-framework","08.migrations/14.django-serialization-framework",{"title":390,"path":391,"stem":392,"children":393},"Authentication and Authorization","/authentication-and-authorization","09.authentication-and-authorization/01.index",[394,395,399,403,407,411,415,419,423,427,431,435],{"title":390,"path":391,"stem":392},{"title":396,"path":397,"stem":398},"Overview of Django's Authentication System","/authentication-and-authorization/overview-of-django-authentication-system","09.authentication-and-authorization/02.overview-of-django-authentication-system",{"title":400,"path":401,"stem":402},"Users and Groups","/authentication-and-authorization/users-and-groups","09.authentication-and-authorization/03.users-and-groups",{"title":404,"path":405,"stem":406},"Permissions","/authentication-and-authorization/permissions","09.authentication-and-authorization/04.permissions",{"title":408,"path":409,"stem":410},"Password Management","/authentication-and-authorization/password-management","09.authentication-and-authorization/05.password-management",{"title":412,"path":413,"stem":414},"Authentication Views","/authentication-and-authorization/authentication-views","09.authentication-and-authorization/06.authentication-views",{"title":416,"path":417,"stem":418},"Login and Logout","/authentication-and-authorization/login-and-logout","09.authentication-and-authorization/07.login-and-logout",{"title":420,"path":421,"stem":422},"Custom User Models","/authentication-and-authorization/custom-user-models","09.authentication-and-authorization/08.custom-user-models",{"title":424,"path":425,"stem":426},"Middleware for Authentication","/authentication-and-authorization/middleware-for-authentication","09.authentication-and-authorization/09.middleware-for-authentication",{"title":428,"path":429,"stem":430},"Authorization in Views and Templates","/authentication-and-authorization/authorization-in-views-and-templates","09.authentication-and-authorization/10.authorization-in-views-and-templates",{"title":432,"path":433,"stem":434},"Integrating Social Authentication","/authentication-and-authorization/integrating-social-authentication","09.authentication-and-authorization/11.integrating-social-authentication",{"title":436,"path":437,"stem":438},"Security Best Practices","/authentication-and-authorization/security-best-practices","09.authentication-and-authorization/12.security-best-practices",{"title":440,"path":441,"stem":442,"children":443},"Sessions, Cookies, and State","/sessions-cookies-state","10.sessions-cookies-state/01.index",[444,446,450,454,458],{"title":445,"path":441,"stem":442},"Sessions, Cookies, and State Management",{"title":447,"path":448,"stem":449},"Introduction to Sessions","/sessions-cookies-state/introduction-to-sessions","10.sessions-cookies-state/02.introduction-to-sessions",{"title":451,"path":452,"stem":453},"Working with Cookies","/sessions-cookies-state/working-with-cookies","10.sessions-cookies-state/03.working-with-cookies",{"title":455,"path":456,"stem":457},"Server-Side Session Storage Options","/sessions-cookies-state/server-side-session-storage-options","10.sessions-cookies-state/04.server-side-session-storage-options",{"title":459,"path":460,"stem":461},"Session Security","/sessions-cookies-state/session-security","10.sessions-cookies-state/05.session-security",{"title":463,"path":464,"stem":465,"children":466},"Working with Files","/working-with-files","11.working-with-files/01.index",[467,468,472,476,480,484],{"title":463,"path":464,"stem":465},{"title":469,"path":470,"stem":471},"Files in Models","/working-with-files/files-in-models","11.working-with-files/02.files-in-models",{"title":473,"path":474,"stem":475},"The File Object","/working-with-files/the-file-object","11.working-with-files/03.the-file-object",{"title":477,"path":478,"stem":479},"Storage Backends","/working-with-files/storage-backends","11.working-with-files/04.storage-backends",{"title":481,"path":482,"stem":483},"Using Cloud Storage Providers","/working-with-files/using-cloud-storage-providers","11.working-with-files/05.using-cloud-storage-providers",{"title":485,"path":486,"stem":487},"Managing Media in Production","/working-with-files/managing-media-in-production","11.working-with-files/06.managing-media-in-production",{"title":489,"path":490,"stem":491,"children":492},"Admin Site","/admin-site","12.admin-site/01.index",[493,494,498,502,506,510],{"title":489,"path":490,"stem":491},{"title":495,"path":496,"stem":497},"Enabling the Admin","/admin-site/enabling-the-admin","12.admin-site/02.enabling-the-admin",{"title":499,"path":500,"stem":501},"Registering Models","/admin-site/registering-models","12.admin-site/03.registering-models",{"title":503,"path":504,"stem":505},"Customizing Admin Display","/admin-site/customizing-admin-display","12.admin-site/04.customizing-admin-display",{"title":507,"path":508,"stem":509},"Admin Actions","/admin-site/admin-actions","12.admin-site/05.admin-actions",{"title":511,"path":512,"stem":513},"Admin Security Best Practices","/admin-site/admin-security-best-practices","12.admin-site/06.admin-security-best-practices",{"title":515,"path":516,"stem":517,"children":518},"Middleware","/middleware","13.middleware/01.index",[519,520,524,528,532,536],{"title":515,"path":516,"stem":517},{"title":521,"path":522,"stem":523},"Middleware Overview","/middleware/middleware-overview","13.middleware/02.middleware-overview",{"title":525,"path":526,"stem":527},"Built-in Middleware","/middleware/built-in-middleware","13.middleware/03.built-in-middleware",{"title":529,"path":530,"stem":531},"Creating Custom Middleware","/middleware/creating-custom-middleware","13.middleware/04.creating-custom-middleware",{"title":533,"path":534,"stem":535},"Middleware Ordering","/middleware/middleware-ordering","13.middleware/05.middleware-ordering",{"title":537,"path":538,"stem":539},"Performance and Debugging","/middleware/performance-and-debugging","13.middleware/06.performance-and-debugging",{"title":541,"path":542,"stem":543,"children":544},"Security","/security","14.security/01.index",[545,546,550,554,558,562,566,570,574],{"title":541,"path":542,"stem":543},{"title":547,"path":548,"stem":549},"Django Security Philosophy","/security/django-security-philosophy","14.security/02.django-security-philosophy",{"title":551,"path":552,"stem":553},"Cross Site Request Forgery","/security/cross-site-request-forgery","14.security/03.cross-site-request-forgery",{"title":555,"path":556,"stem":557},"Cross Site Scripting","/security/cross-site-scripting","14.security/04.cross-site-scripting",{"title":559,"path":560,"stem":561},"SQL Injection Protection","/security/sql-injection-protection","14.security/05.sql-injection-protection",{"title":563,"path":564,"stem":565},"Clickjacking Protection","/security/clickjacking-protection","14.security/06.clickjacking-protection",{"title":567,"path":568,"stem":569},"HTTPS Setup and HSTS","/security/https-setup-and-hsts","14.security/07.https-setup-and-hsts",{"title":571,"path":572,"stem":573},"Password Storage and Cryptography","/security/password-storage-and-cryptography","14.security/08.password-storage-and-cryptography",{"title":575,"path":576,"stem":577},"Secure Deployment Checklist","/security/secure-deployment-checklist","14.security/09.secure-deployment-checklist",{"title":579,"path":580,"stem":581,"children":582},"Testing","/testing","15.testing/01.index",[583,584,588,592,596,600,604,608,612,616,620],{"title":579,"path":580,"stem":581},{"title":585,"path":586,"stem":587},"Introduction to Django Testing","/testing/introduction-to-django-testing","15.testing/02.introduction-to-django-testing",{"title":589,"path":590,"stem":591},"Writing and Running Tests","/testing/writing-and-running-tests","15.testing/03.writing-and-running-tests",{"title":593,"path":594,"stem":595},"Test Tools","/testing/test-tools","15.testing/04.test-tools",{"title":597,"path":598,"stem":599},"Testing Models","/testing/testing-models","15.testing/05.testing-models",{"title":601,"path":602,"stem":603},"Testing Views","/testing/testing-views","15.testing/06.testing-views",{"title":605,"path":606,"stem":607},"Testing Forms","/testing/testing-forms","15.testing/07.testing-forms",{"title":609,"path":610,"stem":611},"Testing Templates","/testing/testing-templates","15.testing/08.testing-templates",{"title":613,"path":614,"stem":615},"Testing Authentication","/testing/testing-authentication","15.testing/09.testing-authentication",{"title":617,"path":618,"stem":619},"Advanced Testing Topics","/testing/advanced-testing-topics","15.testing/10.advanced-testing-topics",{"title":621,"path":622,"stem":623},"Performance Testing","/testing/performance-testing","15.testing/11.performance-testing",{"title":625,"path":626,"stem":627,"children":628},"Static Assets and Frontend Integration","/static-assets-and-frontend-integration","16.static-assets-and-frontend-integration/01.index",[629,630,634,638,642,646],{"title":625,"path":626,"stem":627},{"title":631,"path":632,"stem":633},"Working with Static Files","/static-assets-and-frontend-integration/working-with-static-files","16.static-assets-and-frontend-integration/02.working-with-static-files",{"title":635,"path":636,"stem":637},"Integrating CSS and JavaScript","/static-assets-and-frontend-integration/integrating-css-and-javascript","16.static-assets-and-frontend-integration/03.integrating-css-and-javascript",{"title":639,"path":640,"stem":641},"Using Build Tools like Vite or Webpack","/static-assets-and-frontend-integration/using-build-tools-like-vite-or-webpack","16.static-assets-and-frontend-integration/04.using-build-tools-like-vite-or-webpack",{"title":643,"path":644,"stem":645},"Using React or Vue with Django","/static-assets-and-frontend-integration/using-react-or-vue-with-django","16.static-assets-and-frontend-integration/05.using-react-or-vue-with-django",{"title":647,"path":648,"stem":649},"Managing CORS","/static-assets-and-frontend-integration/managing-cors","16.static-assets-and-frontend-integration/06.managing-cors",{"title":651,"path":652,"stem":653,"children":654},"Internationalization and Localization","/internationalization-and-localization","17.internationalization-and-localization/01.index",[655,656,660,664,668],{"title":651,"path":652,"stem":653},{"title":657,"path":658,"stem":659},"Enabling Translation","/internationalization-and-localization/enabling-translation","17.internationalization-and-localization/02.enabling-translation",{"title":661,"path":662,"stem":663},"Translating Text in Code and Templates","/internationalization-and-localization/translating-text-in-code-and-templates","17.internationalization-and-localization/03.translating-text-in-code-and-templates",{"title":665,"path":666,"stem":667},"Timezone Support","/internationalization-and-localization/timezone-support","17.internationalization-and-localization/04.timezone-support",{"title":669,"path":670,"stem":671},"Locale Middleware","/internationalization-and-localization/locale-middleware","17.internationalization-and-localization/05.locale-middleware",{"title":673,"path":674,"stem":675,"children":676},"Caching","/caching","18.caching/01.index",[677,678,682,686,690,694,698],{"title":673,"path":674,"stem":675},{"title":679,"path":680,"stem":681},"Introduction to Caching","/caching/introduction-to-caching","18.caching/02.introduction-to-caching",{"title":683,"path":684,"stem":685},"Cache Backends","/caching/cache-backends","18.caching/03.cache-backends",{"title":687,"path":688,"stem":689},"Per View Caching","/caching/per-view-caching","18.caching/04.per-view-caching",{"title":691,"path":692,"stem":693},"Low Level Cache API","/caching/low-level-cache-api","18.caching/05.low-level-cache-api",{"title":695,"path":696,"stem":697},"Template Fragment Caching","/caching/template-fragment-caching","18.caching/06.template-fragment-caching",{"title":699,"path":700,"stem":701},"Deployment Level Caching Patterns","/caching/deployment-level-caching-patterns","18.caching/07.deployment-level-caching-patterns",{"title":703,"path":704,"stem":705,"children":706},"Asynchronous Django","/asynchronous-django","19.asynchronous-django/01.index",[707,708,712,716,720,724,728,732],{"title":703,"path":704,"stem":705},{"title":709,"path":710,"stem":711},"Introduction to ASGI","/asynchronous-django/introduction-to-asgi","19.asynchronous-django/02.introduction-to-asgi",{"title":713,"path":714,"stem":715},"Async Views","/asynchronous-django/async-views","19.asynchronous-django/03.async-views",{"title":717,"path":718,"stem":719},"Async ORM Status","/asynchronous-django/async-orm-status","19.asynchronous-django/04.async-orm-status",{"title":721,"path":722,"stem":723},"WebSockets with Channels","/asynchronous-django/websockets-with-channels","19.asynchronous-django/05.websockets-with-channels",{"title":725,"path":726,"stem":727},"Background Tasks with Celery or RQ","/asynchronous-django/background-tasks-with-celery-or-rq","19.asynchronous-django/06.background-tasks-with-celery-or-rq",{"title":729,"path":730,"stem":731},"Asynchronous Support","/asynchronous-django/asynchronous-support","19.asynchronous-django/07.asynchronous-support",{"title":733,"path":734,"stem":735},"Django's Tasks Framework","/asynchronous-django/django-tasks-framework","19.asynchronous-django/08.django-tasks-framework",{"title":737,"path":738,"stem":739,"children":740},"Deployment","/deployment","20.deployment/01.index",[741,742,746,750,754,758,762,766,770],{"title":737,"path":738,"stem":739},{"title":743,"path":744,"stem":745},"Preparing for Production","/deployment/preparing-for-production","20.deployment/02.preparing-for-production",{"title":747,"path":748,"stem":749},"Using WSGI and ASGI Servers","/deployment/using-wsgi-and-asgi-servers","20.deployment/03.using-wsgi-and-asgi-servers",{"title":751,"path":752,"stem":753},"Deploying on Linux Servers","/deployment/deploying-on-linux-servers","20.deployment/04.deploying-on-linux-servers",{"title":755,"path":756,"stem":757},"Using Docker","/deployment/using-docker","20.deployment/05.using-docker",{"title":759,"path":760,"stem":761},"Cloud Deployment Guides","/deployment/cloud-deployment-guides","20.deployment/06.cloud-deployment-guides",{"title":763,"path":764,"stem":765},"Scaling and Load Balancing","/deployment/scaling-and-load-balancing","20.deployment/07.scaling-and-load-balancing",{"title":767,"path":768,"stem":769},"Monitoring and Logging","/deployment/monitoring-and-logging","20.deployment/08.monitoring-and-logging",{"title":771,"path":772,"stem":773},"Backup Strategies","/deployment/backup-strategies","20.deployment/09.backup-strategies",{"title":775,"path":776,"stem":777,"children":778},"Performance and Optimization","/performance-and-optimization","21.performance-and-optimization/01.index",[779,780,784,788,792,796],{"title":775,"path":776,"stem":777},{"title":781,"path":782,"stem":783},"Query Optimization","/performance-and-optimization/query-optimization","21.performance-and-optimization/02.query-optimization",{"title":785,"path":786,"stem":787},"Template Rendering Optimization","/performance-and-optimization/template-rendering-optimization","21.performance-and-optimization/03.template-rendering-optimization",{"title":789,"path":790,"stem":791},"Using Select Related and Prefetch Related","/performance-and-optimization/using-select-related-and-prefetch-related","21.performance-and-optimization/04.using-select-related-and-prefetch-related",{"title":793,"path":794,"stem":795},"Caching Strategies","/performance-and-optimization/caching-strategies","21.performance-and-optimization/05.caching-strategies",{"title":797,"path":798,"stem":799},"Profiling Django Apps","/performance-and-optimization/profiling-django-apps","21.performance-and-optimization/06.profiling-django-apps",{"title":801,"path":802,"stem":803,"children":804},"Advanced and Expert Topics","/advanced-and-expert-topics","22.advanced-and-expert-topics/01.index",[805,806,810,814,818,822,826,830,834,838,842,846],{"title":801,"path":802,"stem":803},{"title":807,"path":808,"stem":809},"System Architecture Patterns","/advanced-and-expert-topics/system-architecture-patterns","22.advanced-and-expert-topics/02.system-architecture-patterns",{"title":811,"path":812,"stem":813},"Domain Driven Design with Django","/advanced-and-expert-topics/domain-driven-design-with-django","22.advanced-and-expert-topics/03.domain-driven-design-with-django",{"title":815,"path":816,"stem":817},"Building Large Scale Django Projects","/advanced-and-expert-topics/building-large-scale-django-projects","22.advanced-and-expert-topics/04.building-large-scale-django-projects",{"title":819,"path":820,"stem":821},"Plugin Architectures for Django Apps","/advanced-and-expert-topics/plugin-architectures-for-django-apps","22.advanced-and-expert-topics/05.plugin-architectures-for-django-apps",{"title":823,"path":824,"stem":825},"Extending Django's Core","/advanced-and-expert-topics/extending-djangos-core","22.advanced-and-expert-topics/06.extending-djangos-core",{"title":827,"path":828,"stem":829},"Custom ORM Expressions","/advanced-and-expert-topics/custom-orm-expressions","22.advanced-and-expert-topics/07.custom-orm-expressions",{"title":831,"path":832,"stem":833},"Custom Management Commands","/advanced-and-expert-topics/custom-management-commands","22.advanced-and-expert-topics/08.custom-management-commands",{"title":835,"path":836,"stem":837},"Working with Signals","/advanced-and-expert-topics/working-with-signals","22.advanced-and-expert-topics/09.working-with-signals",{"title":839,"path":840,"stem":841},"Building Reusable Django Packages","/advanced-and-expert-topics/building-reusable-django-packages","22.advanced-and-expert-topics/10.building-reusable-django-packages",{"title":843,"path":844,"stem":845},"Integrating Microservices","/advanced-and-expert-topics/integrating-microservices","22.advanced-and-expert-topics/11.integrating-microservices",{"title":847,"path":848,"stem":849},"Advanced Security Hardening","/advanced-and-expert-topics/advanced-security-hardening","22.advanced-and-expert-topics/12.advanced-security-hardening",{"title":851,"path":852,"stem":853,"children":854},"Logging in Django","/logging-in-django","23.logging-in-django/01.index",[855],{"title":851,"path":852,"stem":853},{"title":857,"path":858,"stem":859,"children":860},"FAQ and Troubleshooting","/faq-and-troubleshooting","24.faq-and-troubleshooting/01.index",[861],{"title":857,"path":858,"stem":859},{"title":863,"path":864,"stem":865,"children":866},"External Packages and Ecosystem","/external-packages-and-ecosystem","25.external-packages-and-ecosystem/01.index",[867],{"title":863,"path":864,"stem":865},{"title":869,"path":870,"stem":871,"children":872},"Django Internals and Contributing","/django-internals-and-contributing","26.django-internals-and-contributing/01.index",[873],{"title":869,"path":870,"stem":871},{"title":875,"path":876,"stem":877,"children":878},"Microservices with Django","/microservices-with-django","27.microservices-with-django/01.index",[879,880,884,888,892,896,900,904,908,912,916,920,924],{"title":875,"path":876,"stem":877},{"title":881,"path":882,"stem":883},"What Is a Microservice?","/microservices-with-django/what-is-a-microservice","27.microservices-with-django/02.what-is-a-microservice",{"title":885,"path":886,"stem":887},"Introducing the Django Microservices Architecture","/microservices-with-django/django-microservices-architecture","27.microservices-with-django/03.django-microservices-architecture",{"title":889,"path":890,"stem":891},"Setting Up the Development and Runtime Environment","/microservices-with-django/development-environment","27.microservices-with-django/04.development-environment",{"title":893,"path":894,"stem":895},"Cloud-native Data Processing with MongoDB","/microservices-with-django/cloud-native-data-processing","27.microservices-with-django/05.cloud-native-data-processing",{"title":897,"path":898,"stem":899},"Creating RESTful APIs for Microservices","/microservices-with-django/restful-apis","27.microservices-with-django/06.restful-apis",{"title":901,"path":902,"stem":903},"Orchestrating Microservices with Celery and RabbitMQ","/microservices-with-django/orchestrating-celery-rabbitmq","27.microservices-with-django/07.orchestrating-celery-rabbitmq",{"title":905,"path":906,"stem":907},"Testing Microservices","/microservices-with-django/testing-microservices","27.microservices-with-django/08.testing-microservices",{"title":909,"path":910,"stem":911},"Deploying Microservices","/microservices-with-django/deploying-microservices","27.microservices-with-django/09.deploying-microservices",{"title":913,"path":914,"stem":915},"Securing Microservices","/microservices-with-django/securing-microservices","27.microservices-with-django/10.securing-microservices",{"title":917,"path":918,"stem":919},"Improving Microservices Performance with Caching","/microservices-with-django/performance-caching","27.microservices-with-django/11.performance-caching",{"title":921,"path":922,"stem":923},"Best Practices","/microservices-with-django/best-practices","27.microservices-with-django/12.best-practices",{"title":925,"path":926,"stem":927},"Transforming a Monolithic Web App into a Microservice version","/microservices-with-django/monolith-to-microservices","27.microservices-with-django/13.monolith-to-microservices",{"title":929,"path":930,"stem":931,"children":932},"Releases","/releases","releases",[933,936,940,944,948,952,956,960,964,968,972,976,980,984,988,992,996,1000,1004,1008,1012],{"title":934,"path":930,"stem":935},"Django Releases","releases/index",{"title":937,"path":938,"stem":939},"Django 5.1.10 release notes","/releases/5.1.10","releases/5.1.10",{"title":941,"path":942,"stem":943},"Django 5.1.11 release notes","/releases/5.1.11","releases/5.1.11",{"title":945,"path":946,"stem":947},"Django 5.1.12 release notes","/releases/5.1.12","releases/5.1.12",{"title":949,"path":950,"stem":951},"Django 5.1.13 release notes","/releases/5.1.13","releases/5.1.13",{"title":953,"path":954,"stem":955},"Django 5.1.14 release notes","/releases/5.1.14","releases/5.1.14",{"title":957,"path":958,"stem":959},"Django 5.1.15 release notes","/releases/5.1.15","releases/5.1.15",{"title":961,"path":962,"stem":963},"Django 5.2 release notes","/releases/5.2","releases/5.2",{"title":965,"path":966,"stem":967},"Django 5.2.1 release notes","/releases/5.2.1","releases/5.2.1",{"title":969,"path":970,"stem":971},"Django 5.2.10 release notes","/releases/5.2.10","releases/5.2.10",{"title":973,"path":974,"stem":975},"Django 5.2.2 release notes","/releases/5.2.2","releases/5.2.2",{"title":977,"path":978,"stem":979},"Django 5.2.3 release notes","/releases/5.2.3","releases/5.2.3",{"title":981,"path":982,"stem":983},"Django 5.2.4 release notes","/releases/5.2.4","releases/5.2.4",{"title":985,"path":986,"stem":987},"Django 5.2.5 release notes","/releases/5.2.5","releases/5.2.5",{"title":989,"path":990,"stem":991},"Django 5.2.6 release notes","/releases/5.2.6","releases/5.2.6",{"title":993,"path":994,"stem":995},"Django 5.2.7 release notes","/releases/5.2.7","releases/5.2.7",{"title":997,"path":998,"stem":999},"Django 5.2.8 release notes","/releases/5.2.8","releases/5.2.8",{"title":1001,"path":1002,"stem":1003},"Django 5.2.9 release notes","/releases/5.2.9","releases/5.2.9",{"title":1005,"path":1006,"stem":1007},"Django 6.0 release notes","/releases/6.0","releases/6.0",{"title":1009,"path":1010,"stem":1011},"Django 6.0.1 release notes","/releases/6.0.1","releases/6.0.1",{"title":1013,"path":1014,"stem":1015},"Django 6.1 release notes - UNDER DEVELOPMENT","/releases/6.1","releases/6.1",{"id":1017,"title":889,"body":1018,"description":1028,"extension":9606,"links":9607,"meta":9608,"navigation":1109,"path":890,"seo":9609,"stem":891,"__hash__":9610},"docs/27.microservices-with-django/04.development-environment.md",{"type":1019,"value":1020,"toc":9576},"minimark",[1021,1025,1029,1034,1039,1042,1206,1210,1213,1333,1337,1471,1475,1755,3719,3723,3727,3999,4003,5267,5271,5516,5520,6018,6022,6026,6367,6371,6927,6931,7184,7188,7192,7872,7876,7993,7997,8814,8818,9284,9288,9292,9440,9444,9538,9542,9545,9570,9573],[1022,1023,889],"h1",{"id":1024},"setting-up-the-development-and-runtime-environment",[1026,1027,1028],"p",{},"Setting up a proper development and runtime environment is crucial for successful microservices development with Django. This section covers everything from local development setup to production-ready deployment configurations.",[1030,1031,1033],"h2",{"id":1032},"development-environment-setup","Development Environment Setup",[1035,1036,1038],"h3",{"id":1037},"_1-prerequisites-installation","1. Prerequisites Installation",[1026,1040,1041],{},"First, ensure you have the necessary tools installed:",[1043,1044,1049],"pre",{"className":1045,"code":1046,"language":1047,"meta":1048,"style":1048},"language-bash shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","# Install Python 3.11+\nbrew install python@3.11  # macOS\n# or\nsudo apt-get install python3.11 python3.11-venv  # Ubuntu\n\n# Install Docker and Docker Compose\nbrew install docker docker-compose  # macOS\n# or follow Docker's official installation guide\n\n# Install Git\nbrew install git  # macOS\n# or\nsudo apt-get install git  # Ubuntu\n\n# Install additional tools\nbrew install httpie jq  # API testing and JSON processing\n","bash","",[1050,1051,1052,1061,1078,1084,1104,1111,1117,1132,1138,1143,1149,1161,1166,1179,1184,1190],"code",{"__ignoreMap":1048},[1053,1054,1057],"span",{"class":1055,"line":1056},"line",1,[1053,1058,1060],{"class":1059},"s9Tkl","# Install Python 3.11+\n",[1053,1062,1064,1068,1072,1075],{"class":1055,"line":1063},2,[1053,1065,1067],{"class":1066},"sYn-s","brew",[1053,1069,1071],{"class":1070},"sTbE_"," install",[1053,1073,1074],{"class":1070}," python@3.11",[1053,1076,1077],{"class":1059},"  # macOS\n",[1053,1079,1081],{"class":1055,"line":1080},3,[1053,1082,1083],{"class":1059},"# or\n",[1053,1085,1087,1090,1093,1095,1098,1101],{"class":1055,"line":1086},4,[1053,1088,1089],{"class":1066},"sudo",[1053,1091,1092],{"class":1070}," apt-get",[1053,1094,1071],{"class":1070},[1053,1096,1097],{"class":1070}," python3.11",[1053,1099,1100],{"class":1070}," python3.11-venv",[1053,1102,1103],{"class":1059},"  # Ubuntu\n",[1053,1105,1107],{"class":1055,"line":1106},5,[1053,1108,1110],{"emptyLinePlaceholder":1109},true,"\n",[1053,1112,1114],{"class":1055,"line":1113},6,[1053,1115,1116],{"class":1059},"# Install Docker and Docker Compose\n",[1053,1118,1120,1122,1124,1127,1130],{"class":1055,"line":1119},7,[1053,1121,1067],{"class":1066},[1053,1123,1071],{"class":1070},[1053,1125,1126],{"class":1070}," docker",[1053,1128,1129],{"class":1070}," docker-compose",[1053,1131,1077],{"class":1059},[1053,1133,1135],{"class":1055,"line":1134},8,[1053,1136,1137],{"class":1059},"# or follow Docker's official installation guide\n",[1053,1139,1141],{"class":1055,"line":1140},9,[1053,1142,1110],{"emptyLinePlaceholder":1109},[1053,1144,1146],{"class":1055,"line":1145},10,[1053,1147,1148],{"class":1059},"# Install Git\n",[1053,1150,1152,1154,1156,1159],{"class":1055,"line":1151},11,[1053,1153,1067],{"class":1066},[1053,1155,1071],{"class":1070},[1053,1157,1158],{"class":1070}," git",[1053,1160,1077],{"class":1059},[1053,1162,1164],{"class":1055,"line":1163},12,[1053,1165,1083],{"class":1059},[1053,1167,1169,1171,1173,1175,1177],{"class":1055,"line":1168},13,[1053,1170,1089],{"class":1066},[1053,1172,1092],{"class":1070},[1053,1174,1071],{"class":1070},[1053,1176,1158],{"class":1070},[1053,1178,1103],{"class":1059},[1053,1180,1182],{"class":1055,"line":1181},14,[1053,1183,1110],{"emptyLinePlaceholder":1109},[1053,1185,1187],{"class":1055,"line":1186},15,[1053,1188,1189],{"class":1059},"# Install additional tools\n",[1053,1191,1193,1195,1197,1200,1203],{"class":1055,"line":1192},16,[1053,1194,1067],{"class":1066},[1053,1196,1071],{"class":1070},[1053,1198,1199],{"class":1070}," httpie",[1053,1201,1202],{"class":1070}," jq",[1053,1204,1205],{"class":1059},"  # API testing and JSON processing\n",[1035,1207,1209],{"id":1208},"_2-project-structure-setup","2. Project Structure Setup",[1026,1211,1212],{},"Create a well-organized project structure for multiple microservices:",[1043,1214,1216],{"className":1045,"code":1215,"language":1047,"meta":1048,"style":1048},"# Create main project directory\nmkdir django-microservices\ncd django-microservices\n\n# Create individual service directories\nmkdir -p services/{user-service,product-service,order-service,payment-service}\nmkdir -p infrastructure/{docker,kubernetes,monitoring}\nmkdir -p shared/{libraries,configs}\nmkdir -p scripts\nmkdir -p docs\n\n# Create environment files\ntouch .env.development\ntouch .env.production\ntouch docker-compose.yml\ntouch docker-compose.prod.yml\n",[1050,1217,1218,1223,1231,1239,1243,1248,1259,1268,1277,1286,1295,1299,1304,1312,1319,1326],{"__ignoreMap":1048},[1053,1219,1220],{"class":1055,"line":1056},[1053,1221,1222],{"class":1059},"# Create main project directory\n",[1053,1224,1225,1228],{"class":1055,"line":1063},[1053,1226,1227],{"class":1066},"mkdir",[1053,1229,1230],{"class":1070}," django-microservices\n",[1053,1232,1233,1237],{"class":1055,"line":1080},[1053,1234,1236],{"class":1235},"sJdAF","cd",[1053,1238,1230],{"class":1070},[1053,1240,1241],{"class":1055,"line":1086},[1053,1242,1110],{"emptyLinePlaceholder":1109},[1053,1244,1245],{"class":1055,"line":1106},[1053,1246,1247],{"class":1059},"# Create individual service directories\n",[1053,1249,1250,1252,1256],{"class":1055,"line":1113},[1053,1251,1227],{"class":1066},[1053,1253,1255],{"class":1254},"sz9Cv"," -p",[1053,1257,1258],{"class":1070}," services/{user-service,product-service,order-service,payment-service}\n",[1053,1260,1261,1263,1265],{"class":1055,"line":1119},[1053,1262,1227],{"class":1066},[1053,1264,1255],{"class":1254},[1053,1266,1267],{"class":1070}," infrastructure/{docker,kubernetes,monitoring}\n",[1053,1269,1270,1272,1274],{"class":1055,"line":1134},[1053,1271,1227],{"class":1066},[1053,1273,1255],{"class":1254},[1053,1275,1276],{"class":1070}," shared/{libraries,configs}\n",[1053,1278,1279,1281,1283],{"class":1055,"line":1140},[1053,1280,1227],{"class":1066},[1053,1282,1255],{"class":1254},[1053,1284,1285],{"class":1070}," scripts\n",[1053,1287,1288,1290,1292],{"class":1055,"line":1145},[1053,1289,1227],{"class":1066},[1053,1291,1255],{"class":1254},[1053,1293,1294],{"class":1070}," docs\n",[1053,1296,1297],{"class":1055,"line":1151},[1053,1298,1110],{"emptyLinePlaceholder":1109},[1053,1300,1301],{"class":1055,"line":1163},[1053,1302,1303],{"class":1059},"# Create environment files\n",[1053,1305,1306,1309],{"class":1055,"line":1168},[1053,1307,1308],{"class":1066},"touch",[1053,1310,1311],{"class":1070}," .env.development\n",[1053,1313,1314,1316],{"class":1055,"line":1181},[1053,1315,1308],{"class":1066},[1053,1317,1318],{"class":1070}," .env.production\n",[1053,1320,1321,1323],{"class":1055,"line":1186},[1053,1322,1308],{"class":1066},[1053,1324,1325],{"class":1070}," docker-compose.yml\n",[1053,1327,1328,1330],{"class":1055,"line":1192},[1053,1329,1308],{"class":1066},[1053,1331,1332],{"class":1070}," docker-compose.prod.yml\n",[1035,1334,1336],{"id":1335},"_3-virtual-environment-setup","3. Virtual Environment Setup",[1043,1338,1340],{"className":1045,"code":1339,"language":1047,"meta":1048,"style":1048},"# Create virtual environment for each service\ncd services/user-service\npython3.11 -m venv venv\nsource venv/bin/activate\n\n# Install base requirements\npip install --upgrade pip\npip install django djangorestframework python-decouple\npip freeze > requirements.txt\n\n# Create Django project\ndjango-admin startproject user_service .\ncd user_service\npython manage.py startapp users\n",[1050,1341,1342,1347,1354,1368,1376,1380,1385,1398,1413,1427,1431,1436,1450,1457],{"__ignoreMap":1048},[1053,1343,1344],{"class":1055,"line":1056},[1053,1345,1346],{"class":1059},"# Create virtual environment for each service\n",[1053,1348,1349,1351],{"class":1055,"line":1063},[1053,1350,1236],{"class":1235},[1053,1352,1353],{"class":1070}," services/user-service\n",[1053,1355,1356,1359,1362,1365],{"class":1055,"line":1080},[1053,1357,1358],{"class":1066},"python3.11",[1053,1360,1361],{"class":1254}," -m",[1053,1363,1364],{"class":1070}," venv",[1053,1366,1367],{"class":1070}," venv\n",[1053,1369,1370,1373],{"class":1055,"line":1086},[1053,1371,1372],{"class":1235},"source",[1053,1374,1375],{"class":1070}," venv/bin/activate\n",[1053,1377,1378],{"class":1055,"line":1106},[1053,1379,1110],{"emptyLinePlaceholder":1109},[1053,1381,1382],{"class":1055,"line":1113},[1053,1383,1384],{"class":1059},"# Install base requirements\n",[1053,1386,1387,1390,1392,1395],{"class":1055,"line":1119},[1053,1388,1389],{"class":1066},"pip",[1053,1391,1071],{"class":1070},[1053,1393,1394],{"class":1254}," --upgrade",[1053,1396,1397],{"class":1070}," pip\n",[1053,1399,1400,1402,1404,1407,1410],{"class":1055,"line":1134},[1053,1401,1389],{"class":1066},[1053,1403,1071],{"class":1070},[1053,1405,1406],{"class":1070}," django",[1053,1408,1409],{"class":1070}," djangorestframework",[1053,1411,1412],{"class":1070}," python-decouple\n",[1053,1414,1415,1417,1420,1424],{"class":1055,"line":1140},[1053,1416,1389],{"class":1066},[1053,1418,1419],{"class":1070}," freeze",[1053,1421,1423],{"class":1422},"sVsLi"," >",[1053,1425,1426],{"class":1070}," requirements.txt\n",[1053,1428,1429],{"class":1055,"line":1145},[1053,1430,1110],{"emptyLinePlaceholder":1109},[1053,1432,1433],{"class":1055,"line":1151},[1053,1434,1435],{"class":1059},"# Create Django project\n",[1053,1437,1438,1441,1444,1447],{"class":1055,"line":1163},[1053,1439,1440],{"class":1066},"django-admin",[1053,1442,1443],{"class":1070}," startproject",[1053,1445,1446],{"class":1070}," user_service",[1053,1448,1449],{"class":1070}," .\n",[1053,1451,1452,1454],{"class":1055,"line":1168},[1053,1453,1236],{"class":1235},[1053,1455,1456],{"class":1070}," user_service\n",[1053,1458,1459,1462,1465,1468],{"class":1055,"line":1181},[1053,1460,1461],{"class":1066},"python",[1053,1463,1464],{"class":1070}," manage.py",[1053,1466,1467],{"class":1070}," startapp",[1053,1469,1470],{"class":1070}," users\n",[1035,1472,1474],{"id":1473},"_4-environment-configuration","4. Environment Configuration",[1043,1476,1479],{"className":1477,"code":1478,"language":1461,"meta":1048,"style":1048},"language-python shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","# .env.development\nDEBUG=True\nSECRET_KEY=your-secret-key-here\nDATABASE_URL=postgresql://postgres:password@localhost:5432/user_service_db\nREDIS_URL=redis://localhost:6379/0\nRABBITMQ_URL=amqp://admin:password@localhost:5672/\nCONSUL_HOST=localhost\nCONSUL_PORT=8500\nSERVICE_SECRET_TOKEN=your-service-secret-token\nALLOWED_HOSTS=localhost,127.0.0.1,0.0.0.0\nCORS_ALLOWED_ORIGINS=http://localhost:3000,http://127.0.0.1:3000\n",[1050,1480,1481,1486,1500,1527,1569,1595,1628,1638,1648,1671,1711],{"__ignoreMap":1048},[1053,1482,1483],{"class":1055,"line":1056},[1053,1484,1485],{"class":1059},"# .env.development\n",[1053,1487,1488,1492,1496],{"class":1055,"line":1063},[1053,1489,1491],{"class":1490},"se3Ec","DEBUG",[1053,1493,1495],{"class":1494},"soVBu","=",[1053,1497,1499],{"class":1498},"s8XtY","True\n",[1053,1501,1502,1505,1507,1511,1514,1517,1519,1522,1524],{"class":1055,"line":1080},[1053,1503,1504],{"class":1490},"SECRET_KEY",[1053,1506,1495],{"class":1494},[1053,1508,1510],{"class":1509},"sftqT","your",[1053,1512,1513],{"class":1422},"-",[1053,1515,1516],{"class":1509},"secret",[1053,1518,1513],{"class":1422},[1053,1520,1521],{"class":1509},"key",[1053,1523,1513],{"class":1422},[1053,1525,1526],{"class":1509},"here\n",[1053,1528,1529,1532,1534,1537,1540,1543,1546,1548,1551,1554,1557,1559,1563,1566],{"class":1055,"line":1086},[1053,1530,1531],{"class":1490},"DATABASE_URL",[1053,1533,1495],{"class":1494},[1053,1535,1536],{"class":1509},"postgresql",[1053,1538,1539],{"class":1494},":",[1053,1541,1542],{"class":1422},"//",[1053,1544,1545],{"class":1509},"postgres",[1053,1547,1539],{"class":1494},[1053,1549,1550],{"class":1509},"password",[1053,1552,1553],{"class":1422},"@",[1053,1555,1556],{"class":1509},"localhost",[1053,1558,1539],{"class":1494},[1053,1560,1562],{"class":1561},"s7CZa","5432",[1053,1564,1565],{"class":1422},"/",[1053,1567,1568],{"class":1509},"user_service_db\n",[1053,1570,1571,1574,1576,1579,1581,1583,1585,1587,1590,1592],{"class":1055,"line":1106},[1053,1572,1573],{"class":1490},"REDIS_URL",[1053,1575,1495],{"class":1494},[1053,1577,1578],{"class":1509},"redis",[1053,1580,1539],{"class":1494},[1053,1582,1542],{"class":1422},[1053,1584,1556],{"class":1509},[1053,1586,1539],{"class":1494},[1053,1588,1589],{"class":1561},"6379",[1053,1591,1565],{"class":1422},[1053,1593,1594],{"class":1561},"0\n",[1053,1596,1597,1600,1602,1605,1607,1609,1612,1614,1616,1618,1620,1622,1625],{"class":1055,"line":1113},[1053,1598,1599],{"class":1490},"RABBITMQ_URL",[1053,1601,1495],{"class":1494},[1053,1603,1604],{"class":1509},"amqp",[1053,1606,1539],{"class":1494},[1053,1608,1542],{"class":1422},[1053,1610,1611],{"class":1509},"admin",[1053,1613,1539],{"class":1494},[1053,1615,1550],{"class":1509},[1053,1617,1553],{"class":1422},[1053,1619,1556],{"class":1509},[1053,1621,1539],{"class":1494},[1053,1623,1624],{"class":1561},"5672",[1053,1626,1627],{"class":1422},"/\n",[1053,1629,1630,1633,1635],{"class":1055,"line":1119},[1053,1631,1632],{"class":1490},"CONSUL_HOST",[1053,1634,1495],{"class":1494},[1053,1636,1637],{"class":1509},"localhost\n",[1053,1639,1640,1643,1645],{"class":1055,"line":1134},[1053,1641,1642],{"class":1490},"CONSUL_PORT",[1053,1644,1495],{"class":1494},[1053,1646,1647],{"class":1561},"8500\n",[1053,1649,1650,1653,1655,1657,1659,1662,1664,1666,1668],{"class":1055,"line":1140},[1053,1651,1652],{"class":1490},"SERVICE_SECRET_TOKEN",[1053,1654,1495],{"class":1494},[1053,1656,1510],{"class":1509},[1053,1658,1513],{"class":1422},[1053,1660,1661],{"class":1509},"service",[1053,1663,1513],{"class":1422},[1053,1665,1516],{"class":1509},[1053,1667,1513],{"class":1422},[1053,1669,1670],{"class":1509},"token\n",[1053,1672,1673,1676,1678,1680,1683,1686,1689,1693,1695,1698,1700,1703,1705,1707,1709],{"class":1055,"line":1145},[1053,1674,1675],{"class":1490},"ALLOWED_HOSTS",[1053,1677,1495],{"class":1494},[1053,1679,1556],{"class":1509},[1053,1681,1682],{"class":1494},",",[1053,1684,1685],{"class":1561},"127.0",[1053,1687,1688],{"class":1494},".",[1053,1690,1692],{"class":1691},"sBPpx","0",[1053,1694,1688],{"class":1494},[1053,1696,1697],{"class":1691},"1",[1053,1699,1682],{"class":1494},[1053,1701,1702],{"class":1561},"0.0",[1053,1704,1688],{"class":1494},[1053,1706,1692],{"class":1691},[1053,1708,1688],{"class":1494},[1053,1710,1594],{"class":1691},[1053,1712,1713,1716,1718,1721,1723,1725,1727,1729,1732,1734,1736,1738,1740,1742,1744,1746,1748,1750,1752],{"class":1055,"line":1151},[1053,1714,1715],{"class":1490},"CORS_ALLOWED_ORIGINS",[1053,1717,1495],{"class":1494},[1053,1719,1720],{"class":1509},"http",[1053,1722,1539],{"class":1494},[1053,1724,1542],{"class":1422},[1053,1726,1556],{"class":1509},[1053,1728,1539],{"class":1494},[1053,1730,1731],{"class":1561},"3000",[1053,1733,1682],{"class":1494},[1053,1735,1720],{"class":1509},[1053,1737,1539],{"class":1494},[1053,1739,1542],{"class":1422},[1053,1741,1685],{"class":1561},[1053,1743,1688],{"class":1494},[1053,1745,1692],{"class":1691},[1053,1747,1688],{"class":1494},[1053,1749,1697],{"class":1691},[1053,1751,1539],{"class":1494},[1053,1753,1754],{"class":1561},"3000\n",[1043,1756,1758],{"className":1477,"code":1757,"language":1461,"meta":1048,"style":1048},"# services/user-service/user_service/settings.py\nimport os\nfrom decouple import config\nfrom pathlib import Path\n\nBASE_DIR = Path(__file__).resolve().parent.parent\n\n# Security\nSECRET_KEY = config('SECRET_KEY')\nDEBUG = config('DEBUG', default=False, cast=bool)\nALLOWED_HOSTS = config('ALLOWED_HOSTS', default='').split(',')\n\n# Application definition\nDJANGO_APPS = [\n    'django.contrib.admin',\n    'django.contrib.auth',\n    'django.contrib.contenttypes',\n    'django.contrib.sessions',\n    'django.contrib.messages',\n    'django.contrib.staticfiles',\n]\n\nTHIRD_PARTY_APPS = [\n    'rest_framework',\n    'rest_framework.authtoken',\n    'corsheaders',\n]\n\nLOCAL_APPS = [\n    'users',\n]\n\nINSTALLED_APPS = DJANGO_APPS + THIRD_PARTY_APPS + LOCAL_APPS\n\nMIDDLEWARE = [\n    'corsheaders.middleware.CorsMiddleware',\n    'django.middleware.security.SecurityMiddleware',\n    'django.contrib.sessions.middleware.SessionMiddleware',\n    'django.middleware.common.CommonMiddleware',\n    'django.middleware.csrf.CsrfViewMiddleware',\n    'django.contrib.auth.middleware.AuthenticationMiddleware',\n    'django.contrib.messages.middleware.MessageMiddleware',\n    'django.middleware.clickjacking.XFrameOptionsMiddleware',\n    'users.middleware.RequestTrackingMiddleware',\n    'users.middleware.ServiceAuthMiddleware',\n]\n\nROOT_URLCONF = 'user_service.urls'\n\n# Database\nDATABASES = {\n    'default': {\n        'ENGINE': 'django.db.backends.postgresql',\n        'NAME': config('DB_NAME', default='user_service_db'),\n        'USER': config('DB_USER', default='postgres'),\n        'PASSWORD': config('DB_PASSWORD', default='password'),\n        'HOST': config('DB_HOST', default='localhost'),\n        'PORT': config('DB_PORT', default='5432'),\n        'OPTIONS': {\n            'MAX_CONNS': 20,\n            'CONN_MAX_AGE': 600,\n        }\n    }\n}\n\n# Cache\nCACHES = {\n    'default': {\n        'BACKEND': 'django_redis.cache.RedisCache',\n        'LOCATION': config('REDIS_URL', default='redis://localhost:6379/0'),\n        'OPTIONS': {\n            'CLIENT_CLASS': 'django_redis.client.DefaultClient',\n        }\n    }\n}\n\n# REST Framework\nREST_FRAMEWORK = {\n    'DEFAULT_AUTHENTICATION_CLASSES': [\n        'rest_framework.authentication.TokenAuthentication',\n    ],\n    'DEFAULT_PERMISSION_CLASSES': [\n        'rest_framework.permissions.IsAuthenticated',\n    ],\n    'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',\n    'PAGE_SIZE': 20,\n    'DEFAULT_THROTTLE_CLASSES': [\n        'rest_framework.throttling.AnonRateThrottle',\n        'rest_framework.throttling.UserRateThrottle'\n    ],\n    'DEFAULT_THROTTLE_RATES': {\n        'anon': '100/hour',\n        'user': '1000/hour'\n    }\n}\n\n# CORS\nCORS_ALLOWED_ORIGINS = config('CORS_ALLOWED_ORIGINS', default='').split(',')\nCORS_ALLOW_CREDENTIALS = True\n\n# Logging\nLOGGING = {\n    'version': 1,\n    'disable_existing_loggers': False,\n    'formatters': {\n        'verbose': {\n            'format': '{levelname} {asctime} {module} {process:d} {thread:d} {message}',\n            'style': '{',\n        },\n        'simple': {\n            'format': '{levelname} {message}',\n            'style': '{',\n        },\n    },\n    'handlers': {\n        'file': {\n            'level': 'INFO',\n            'class': 'logging.FileHandler',\n            'filename': 'user_service.log',\n            'formatter': 'verbose',\n        },\n        'console': {\n            'level': 'DEBUG',\n            'class': 'logging.StreamHandler',\n            'formatter': 'simple',\n        },\n    },\n    'root': {\n        'handlers': ['console', 'file'],\n        'level': 'INFO',\n    },\n}\n\n# Service-specific settings\nSERVICE_NAME = 'user-service'\nSERVICE_VERSION = '1.0.0'\nSERVICE_SECRET_TOKEN = config('SERVICE_SECRET_TOKEN')\nCONSUL_HOST = config('CONSUL_HOST', default='localhost')\nCONSUL_PORT = config('CONSUL_PORT', default=8500, cast=int)\nRABBITMQ_URL = config('RABBITMQ_URL', default='amqp://localhost:5672/')\n",[1050,1759,1760,1765,1774,1787,1799,1803,1839,1843,1848,1870,1910,1950,1954,1959,1969,1982,1993,2005,2017,2029,2041,2047,2052,2062,2074,2086,2098,2103,2108,2118,2130,2135,2140,2162,2167,2177,2189,2201,2213,2225,2237,2249,2261,2273,2285,2297,2302,2307,2324,2329,2335,2346,2360,2382,2421,2458,2495,2532,2569,2583,2601,2618,2624,2630,2636,2641,2647,2657,2670,2691,2728,2741,2762,2767,2772,2777,2782,2788,2798,2812,2824,2830,2844,2856,2861,2882,2898,2912,2924,2934,2939,2953,2974,2993,2998,3003,3008,3014,3053,3064,3069,3075,3085,3102,3119,3133,3147,3195,3216,3222,3236,3257,3276,3281,3287,3301,3315,3336,3357,3378,3398,3403,3417,3436,3456,3475,3480,3485,3499,3530,3549,3554,3559,3564,3570,3585,3600,3619,3650,3687],{"__ignoreMap":1048},[1053,1761,1762],{"class":1055,"line":1056},[1053,1763,1764],{"class":1059},"# services/user-service/user_service/settings.py\n",[1053,1766,1767,1771],{"class":1055,"line":1063},[1053,1768,1770],{"class":1769},"siDh9","import",[1053,1772,1773],{"class":1509}," os\n",[1053,1775,1776,1779,1782,1784],{"class":1055,"line":1080},[1053,1777,1778],{"class":1769},"from",[1053,1780,1781],{"class":1509}," decouple ",[1053,1783,1770],{"class":1769},[1053,1785,1786],{"class":1509}," config\n",[1053,1788,1789,1791,1794,1796],{"class":1055,"line":1086},[1053,1790,1778],{"class":1769},[1053,1792,1793],{"class":1509}," pathlib ",[1053,1795,1770],{"class":1769},[1053,1797,1798],{"class":1509}," Path\n",[1053,1800,1801],{"class":1055,"line":1106},[1053,1802,1110],{"emptyLinePlaceholder":1109},[1053,1804,1805,1808,1811,1815,1818,1822,1825,1828,1831,1834,1836],{"class":1055,"line":1113},[1053,1806,1807],{"class":1490},"BASE_DIR",[1053,1809,1810],{"class":1494}," =",[1053,1812,1814],{"class":1813},"siWMO"," Path",[1053,1816,1817],{"class":1494},"(",[1053,1819,1821],{"class":1820},"s131V","__file__",[1053,1823,1824],{"class":1494},").",[1053,1826,1827],{"class":1813},"resolve",[1053,1829,1830],{"class":1494},"().",[1053,1832,1833],{"class":1691},"parent",[1053,1835,1688],{"class":1494},[1053,1837,1838],{"class":1691},"parent\n",[1053,1840,1841],{"class":1055,"line":1119},[1053,1842,1110],{"emptyLinePlaceholder":1109},[1053,1844,1845],{"class":1055,"line":1134},[1053,1846,1847],{"class":1059},"# Security\n",[1053,1849,1850,1852,1854,1857,1859,1863,1865,1867],{"class":1055,"line":1140},[1053,1851,1504],{"class":1490},[1053,1853,1810],{"class":1494},[1053,1855,1856],{"class":1813}," config",[1053,1858,1817],{"class":1494},[1053,1860,1862],{"class":1861},"sbYkP","'",[1053,1864,1504],{"class":1070},[1053,1866,1862],{"class":1861},[1053,1868,1869],{"class":1494},")\n",[1053,1871,1872,1874,1876,1878,1880,1882,1884,1886,1888,1892,1894,1897,1899,1902,1904,1908],{"class":1055,"line":1145},[1053,1873,1491],{"class":1490},[1053,1875,1810],{"class":1494},[1053,1877,1856],{"class":1813},[1053,1879,1817],{"class":1494},[1053,1881,1862],{"class":1861},[1053,1883,1491],{"class":1070},[1053,1885,1862],{"class":1861},[1053,1887,1682],{"class":1494},[1053,1889,1891],{"class":1890},"sqOPj"," default",[1053,1893,1495],{"class":1494},[1053,1895,1896],{"class":1498},"False",[1053,1898,1682],{"class":1494},[1053,1900,1901],{"class":1890}," cast",[1053,1903,1495],{"class":1494},[1053,1905,1907],{"class":1906},"sa2tF","bool",[1053,1909,1869],{"class":1494},[1053,1911,1912,1914,1916,1918,1920,1922,1924,1926,1928,1930,1932,1935,1937,1940,1942,1944,1946,1948],{"class":1055,"line":1151},[1053,1913,1675],{"class":1490},[1053,1915,1810],{"class":1494},[1053,1917,1856],{"class":1813},[1053,1919,1817],{"class":1494},[1053,1921,1862],{"class":1861},[1053,1923,1675],{"class":1070},[1053,1925,1862],{"class":1861},[1053,1927,1682],{"class":1494},[1053,1929,1891],{"class":1890},[1053,1931,1495],{"class":1494},[1053,1933,1934],{"class":1861},"''",[1053,1936,1824],{"class":1494},[1053,1938,1939],{"class":1813},"split",[1053,1941,1817],{"class":1494},[1053,1943,1862],{"class":1861},[1053,1945,1682],{"class":1070},[1053,1947,1862],{"class":1861},[1053,1949,1869],{"class":1494},[1053,1951,1952],{"class":1055,"line":1163},[1053,1953,1110],{"emptyLinePlaceholder":1109},[1053,1955,1956],{"class":1055,"line":1168},[1053,1957,1958],{"class":1059},"# Application definition\n",[1053,1960,1961,1964,1966],{"class":1055,"line":1181},[1053,1962,1963],{"class":1490},"DJANGO_APPS",[1053,1965,1810],{"class":1494},[1053,1967,1968],{"class":1494}," [\n",[1053,1970,1971,1974,1977,1979],{"class":1055,"line":1186},[1053,1972,1973],{"class":1861},"    '",[1053,1975,1976],{"class":1070},"django.contrib.admin",[1053,1978,1862],{"class":1861},[1053,1980,1981],{"class":1494},",\n",[1053,1983,1984,1986,1989,1991],{"class":1055,"line":1192},[1053,1985,1973],{"class":1861},[1053,1987,1988],{"class":1070},"django.contrib.auth",[1053,1990,1862],{"class":1861},[1053,1992,1981],{"class":1494},[1053,1994,1996,1998,2001,2003],{"class":1055,"line":1995},17,[1053,1997,1973],{"class":1861},[1053,1999,2000],{"class":1070},"django.contrib.contenttypes",[1053,2002,1862],{"class":1861},[1053,2004,1981],{"class":1494},[1053,2006,2008,2010,2013,2015],{"class":1055,"line":2007},18,[1053,2009,1973],{"class":1861},[1053,2011,2012],{"class":1070},"django.contrib.sessions",[1053,2014,1862],{"class":1861},[1053,2016,1981],{"class":1494},[1053,2018,2020,2022,2025,2027],{"class":1055,"line":2019},19,[1053,2021,1973],{"class":1861},[1053,2023,2024],{"class":1070},"django.contrib.messages",[1053,2026,1862],{"class":1861},[1053,2028,1981],{"class":1494},[1053,2030,2032,2034,2037,2039],{"class":1055,"line":2031},20,[1053,2033,1973],{"class":1861},[1053,2035,2036],{"class":1070},"django.contrib.staticfiles",[1053,2038,1862],{"class":1861},[1053,2040,1981],{"class":1494},[1053,2042,2044],{"class":1055,"line":2043},21,[1053,2045,2046],{"class":1494},"]\n",[1053,2048,2050],{"class":1055,"line":2049},22,[1053,2051,1110],{"emptyLinePlaceholder":1109},[1053,2053,2055,2058,2060],{"class":1055,"line":2054},23,[1053,2056,2057],{"class":1490},"THIRD_PARTY_APPS",[1053,2059,1810],{"class":1494},[1053,2061,1968],{"class":1494},[1053,2063,2065,2067,2070,2072],{"class":1055,"line":2064},24,[1053,2066,1973],{"class":1861},[1053,2068,2069],{"class":1070},"rest_framework",[1053,2071,1862],{"class":1861},[1053,2073,1981],{"class":1494},[1053,2075,2077,2079,2082,2084],{"class":1055,"line":2076},25,[1053,2078,1973],{"class":1861},[1053,2080,2081],{"class":1070},"rest_framework.authtoken",[1053,2083,1862],{"class":1861},[1053,2085,1981],{"class":1494},[1053,2087,2089,2091,2094,2096],{"class":1055,"line":2088},26,[1053,2090,1973],{"class":1861},[1053,2092,2093],{"class":1070},"corsheaders",[1053,2095,1862],{"class":1861},[1053,2097,1981],{"class":1494},[1053,2099,2101],{"class":1055,"line":2100},27,[1053,2102,2046],{"class":1494},[1053,2104,2106],{"class":1055,"line":2105},28,[1053,2107,1110],{"emptyLinePlaceholder":1109},[1053,2109,2111,2114,2116],{"class":1055,"line":2110},29,[1053,2112,2113],{"class":1490},"LOCAL_APPS",[1053,2115,1810],{"class":1494},[1053,2117,1968],{"class":1494},[1053,2119,2121,2123,2126,2128],{"class":1055,"line":2120},30,[1053,2122,1973],{"class":1861},[1053,2124,2125],{"class":1070},"users",[1053,2127,1862],{"class":1861},[1053,2129,1981],{"class":1494},[1053,2131,2133],{"class":1055,"line":2132},31,[1053,2134,2046],{"class":1494},[1053,2136,2138],{"class":1055,"line":2137},32,[1053,2139,1110],{"emptyLinePlaceholder":1109},[1053,2141,2143,2146,2148,2151,2154,2157,2159],{"class":1055,"line":2142},33,[1053,2144,2145],{"class":1490},"INSTALLED_APPS",[1053,2147,1810],{"class":1494},[1053,2149,2150],{"class":1490}," DJANGO_APPS",[1053,2152,2153],{"class":1422}," +",[1053,2155,2156],{"class":1490}," THIRD_PARTY_APPS",[1053,2158,2153],{"class":1422},[1053,2160,2161],{"class":1490}," LOCAL_APPS\n",[1053,2163,2165],{"class":1055,"line":2164},34,[1053,2166,1110],{"emptyLinePlaceholder":1109},[1053,2168,2170,2173,2175],{"class":1055,"line":2169},35,[1053,2171,2172],{"class":1490},"MIDDLEWARE",[1053,2174,1810],{"class":1494},[1053,2176,1968],{"class":1494},[1053,2178,2180,2182,2185,2187],{"class":1055,"line":2179},36,[1053,2181,1973],{"class":1861},[1053,2183,2184],{"class":1070},"corsheaders.middleware.CorsMiddleware",[1053,2186,1862],{"class":1861},[1053,2188,1981],{"class":1494},[1053,2190,2192,2194,2197,2199],{"class":1055,"line":2191},37,[1053,2193,1973],{"class":1861},[1053,2195,2196],{"class":1070},"django.middleware.security.SecurityMiddleware",[1053,2198,1862],{"class":1861},[1053,2200,1981],{"class":1494},[1053,2202,2204,2206,2209,2211],{"class":1055,"line":2203},38,[1053,2205,1973],{"class":1861},[1053,2207,2208],{"class":1070},"django.contrib.sessions.middleware.SessionMiddleware",[1053,2210,1862],{"class":1861},[1053,2212,1981],{"class":1494},[1053,2214,2216,2218,2221,2223],{"class":1055,"line":2215},39,[1053,2217,1973],{"class":1861},[1053,2219,2220],{"class":1070},"django.middleware.common.CommonMiddleware",[1053,2222,1862],{"class":1861},[1053,2224,1981],{"class":1494},[1053,2226,2228,2230,2233,2235],{"class":1055,"line":2227},40,[1053,2229,1973],{"class":1861},[1053,2231,2232],{"class":1070},"django.middleware.csrf.CsrfViewMiddleware",[1053,2234,1862],{"class":1861},[1053,2236,1981],{"class":1494},[1053,2238,2240,2242,2245,2247],{"class":1055,"line":2239},41,[1053,2241,1973],{"class":1861},[1053,2243,2244],{"class":1070},"django.contrib.auth.middleware.AuthenticationMiddleware",[1053,2246,1862],{"class":1861},[1053,2248,1981],{"class":1494},[1053,2250,2252,2254,2257,2259],{"class":1055,"line":2251},42,[1053,2253,1973],{"class":1861},[1053,2255,2256],{"class":1070},"django.contrib.messages.middleware.MessageMiddleware",[1053,2258,1862],{"class":1861},[1053,2260,1981],{"class":1494},[1053,2262,2264,2266,2269,2271],{"class":1055,"line":2263},43,[1053,2265,1973],{"class":1861},[1053,2267,2268],{"class":1070},"django.middleware.clickjacking.XFrameOptionsMiddleware",[1053,2270,1862],{"class":1861},[1053,2272,1981],{"class":1494},[1053,2274,2276,2278,2281,2283],{"class":1055,"line":2275},44,[1053,2277,1973],{"class":1861},[1053,2279,2280],{"class":1070},"users.middleware.RequestTrackingMiddleware",[1053,2282,1862],{"class":1861},[1053,2284,1981],{"class":1494},[1053,2286,2288,2290,2293,2295],{"class":1055,"line":2287},45,[1053,2289,1973],{"class":1861},[1053,2291,2292],{"class":1070},"users.middleware.ServiceAuthMiddleware",[1053,2294,1862],{"class":1861},[1053,2296,1981],{"class":1494},[1053,2298,2300],{"class":1055,"line":2299},46,[1053,2301,2046],{"class":1494},[1053,2303,2305],{"class":1055,"line":2304},47,[1053,2306,1110],{"emptyLinePlaceholder":1109},[1053,2308,2310,2313,2315,2318,2321],{"class":1055,"line":2309},48,[1053,2311,2312],{"class":1490},"ROOT_URLCONF",[1053,2314,1810],{"class":1494},[1053,2316,2317],{"class":1861}," '",[1053,2319,2320],{"class":1070},"user_service.urls",[1053,2322,2323],{"class":1861},"'\n",[1053,2325,2327],{"class":1055,"line":2326},49,[1053,2328,1110],{"emptyLinePlaceholder":1109},[1053,2330,2332],{"class":1055,"line":2331},50,[1053,2333,2334],{"class":1059},"# Database\n",[1053,2336,2338,2341,2343],{"class":1055,"line":2337},51,[1053,2339,2340],{"class":1490},"DATABASES",[1053,2342,1810],{"class":1494},[1053,2344,2345],{"class":1494}," {\n",[1053,2347,2349,2351,2354,2356,2358],{"class":1055,"line":2348},52,[1053,2350,1973],{"class":1861},[1053,2352,2353],{"class":1070},"default",[1053,2355,1862],{"class":1861},[1053,2357,1539],{"class":1494},[1053,2359,2345],{"class":1494},[1053,2361,2363,2366,2369,2371,2373,2375,2378,2380],{"class":1055,"line":2362},53,[1053,2364,2365],{"class":1861},"        '",[1053,2367,2368],{"class":1070},"ENGINE",[1053,2370,1862],{"class":1861},[1053,2372,1539],{"class":1494},[1053,2374,2317],{"class":1861},[1053,2376,2377],{"class":1070},"django.db.backends.postgresql",[1053,2379,1862],{"class":1861},[1053,2381,1981],{"class":1494},[1053,2383,2385,2387,2390,2392,2394,2396,2398,2400,2403,2405,2407,2409,2411,2413,2416,2418],{"class":1055,"line":2384},54,[1053,2386,2365],{"class":1861},[1053,2388,2389],{"class":1070},"NAME",[1053,2391,1862],{"class":1861},[1053,2393,1539],{"class":1494},[1053,2395,1856],{"class":1813},[1053,2397,1817],{"class":1494},[1053,2399,1862],{"class":1861},[1053,2401,2402],{"class":1070},"DB_NAME",[1053,2404,1862],{"class":1861},[1053,2406,1682],{"class":1494},[1053,2408,1891],{"class":1890},[1053,2410,1495],{"class":1494},[1053,2412,1862],{"class":1861},[1053,2414,2415],{"class":1070},"user_service_db",[1053,2417,1862],{"class":1861},[1053,2419,2420],{"class":1494},"),\n",[1053,2422,2424,2426,2429,2431,2433,2435,2437,2439,2442,2444,2446,2448,2450,2452,2454,2456],{"class":1055,"line":2423},55,[1053,2425,2365],{"class":1861},[1053,2427,2428],{"class":1070},"USER",[1053,2430,1862],{"class":1861},[1053,2432,1539],{"class":1494},[1053,2434,1856],{"class":1813},[1053,2436,1817],{"class":1494},[1053,2438,1862],{"class":1861},[1053,2440,2441],{"class":1070},"DB_USER",[1053,2443,1862],{"class":1861},[1053,2445,1682],{"class":1494},[1053,2447,1891],{"class":1890},[1053,2449,1495],{"class":1494},[1053,2451,1862],{"class":1861},[1053,2453,1545],{"class":1070},[1053,2455,1862],{"class":1861},[1053,2457,2420],{"class":1494},[1053,2459,2461,2463,2466,2468,2470,2472,2474,2476,2479,2481,2483,2485,2487,2489,2491,2493],{"class":1055,"line":2460},56,[1053,2462,2365],{"class":1861},[1053,2464,2465],{"class":1070},"PASSWORD",[1053,2467,1862],{"class":1861},[1053,2469,1539],{"class":1494},[1053,2471,1856],{"class":1813},[1053,2473,1817],{"class":1494},[1053,2475,1862],{"class":1861},[1053,2477,2478],{"class":1070},"DB_PASSWORD",[1053,2480,1862],{"class":1861},[1053,2482,1682],{"class":1494},[1053,2484,1891],{"class":1890},[1053,2486,1495],{"class":1494},[1053,2488,1862],{"class":1861},[1053,2490,1550],{"class":1070},[1053,2492,1862],{"class":1861},[1053,2494,2420],{"class":1494},[1053,2496,2498,2500,2503,2505,2507,2509,2511,2513,2516,2518,2520,2522,2524,2526,2528,2530],{"class":1055,"line":2497},57,[1053,2499,2365],{"class":1861},[1053,2501,2502],{"class":1070},"HOST",[1053,2504,1862],{"class":1861},[1053,2506,1539],{"class":1494},[1053,2508,1856],{"class":1813},[1053,2510,1817],{"class":1494},[1053,2512,1862],{"class":1861},[1053,2514,2515],{"class":1070},"DB_HOST",[1053,2517,1862],{"class":1861},[1053,2519,1682],{"class":1494},[1053,2521,1891],{"class":1890},[1053,2523,1495],{"class":1494},[1053,2525,1862],{"class":1861},[1053,2527,1556],{"class":1070},[1053,2529,1862],{"class":1861},[1053,2531,2420],{"class":1494},[1053,2533,2535,2537,2540,2542,2544,2546,2548,2550,2553,2555,2557,2559,2561,2563,2565,2567],{"class":1055,"line":2534},58,[1053,2536,2365],{"class":1861},[1053,2538,2539],{"class":1070},"PORT",[1053,2541,1862],{"class":1861},[1053,2543,1539],{"class":1494},[1053,2545,1856],{"class":1813},[1053,2547,1817],{"class":1494},[1053,2549,1862],{"class":1861},[1053,2551,2552],{"class":1070},"DB_PORT",[1053,2554,1862],{"class":1861},[1053,2556,1682],{"class":1494},[1053,2558,1891],{"class":1890},[1053,2560,1495],{"class":1494},[1053,2562,1862],{"class":1861},[1053,2564,1562],{"class":1070},[1053,2566,1862],{"class":1861},[1053,2568,2420],{"class":1494},[1053,2570,2572,2574,2577,2579,2581],{"class":1055,"line":2571},59,[1053,2573,2365],{"class":1861},[1053,2575,2576],{"class":1070},"OPTIONS",[1053,2578,1862],{"class":1861},[1053,2580,1539],{"class":1494},[1053,2582,2345],{"class":1494},[1053,2584,2586,2589,2592,2594,2596,2599],{"class":1055,"line":2585},60,[1053,2587,2588],{"class":1861},"            '",[1053,2590,2591],{"class":1070},"MAX_CONNS",[1053,2593,1862],{"class":1861},[1053,2595,1539],{"class":1494},[1053,2597,2598],{"class":1561}," 20",[1053,2600,1981],{"class":1494},[1053,2602,2604,2606,2609,2611,2613,2616],{"class":1055,"line":2603},61,[1053,2605,2588],{"class":1861},[1053,2607,2608],{"class":1070},"CONN_MAX_AGE",[1053,2610,1862],{"class":1861},[1053,2612,1539],{"class":1494},[1053,2614,2615],{"class":1561}," 600",[1053,2617,1981],{"class":1494},[1053,2619,2621],{"class":1055,"line":2620},62,[1053,2622,2623],{"class":1494},"        }\n",[1053,2625,2627],{"class":1055,"line":2626},63,[1053,2628,2629],{"class":1494},"    }\n",[1053,2631,2633],{"class":1055,"line":2632},64,[1053,2634,2635],{"class":1494},"}\n",[1053,2637,2639],{"class":1055,"line":2638},65,[1053,2640,1110],{"emptyLinePlaceholder":1109},[1053,2642,2644],{"class":1055,"line":2643},66,[1053,2645,2646],{"class":1059},"# Cache\n",[1053,2648,2650,2653,2655],{"class":1055,"line":2649},67,[1053,2651,2652],{"class":1490},"CACHES",[1053,2654,1810],{"class":1494},[1053,2656,2345],{"class":1494},[1053,2658,2660,2662,2664,2666,2668],{"class":1055,"line":2659},68,[1053,2661,1973],{"class":1861},[1053,2663,2353],{"class":1070},[1053,2665,1862],{"class":1861},[1053,2667,1539],{"class":1494},[1053,2669,2345],{"class":1494},[1053,2671,2673,2675,2678,2680,2682,2684,2687,2689],{"class":1055,"line":2672},69,[1053,2674,2365],{"class":1861},[1053,2676,2677],{"class":1070},"BACKEND",[1053,2679,1862],{"class":1861},[1053,2681,1539],{"class":1494},[1053,2683,2317],{"class":1861},[1053,2685,2686],{"class":1070},"django_redis.cache.RedisCache",[1053,2688,1862],{"class":1861},[1053,2690,1981],{"class":1494},[1053,2692,2694,2696,2699,2701,2703,2705,2707,2709,2711,2713,2715,2717,2719,2721,2724,2726],{"class":1055,"line":2693},70,[1053,2695,2365],{"class":1861},[1053,2697,2698],{"class":1070},"LOCATION",[1053,2700,1862],{"class":1861},[1053,2702,1539],{"class":1494},[1053,2704,1856],{"class":1813},[1053,2706,1817],{"class":1494},[1053,2708,1862],{"class":1861},[1053,2710,1573],{"class":1070},[1053,2712,1862],{"class":1861},[1053,2714,1682],{"class":1494},[1053,2716,1891],{"class":1890},[1053,2718,1495],{"class":1494},[1053,2720,1862],{"class":1861},[1053,2722,2723],{"class":1070},"redis://localhost:6379/0",[1053,2725,1862],{"class":1861},[1053,2727,2420],{"class":1494},[1053,2729,2731,2733,2735,2737,2739],{"class":1055,"line":2730},71,[1053,2732,2365],{"class":1861},[1053,2734,2576],{"class":1070},[1053,2736,1862],{"class":1861},[1053,2738,1539],{"class":1494},[1053,2740,2345],{"class":1494},[1053,2742,2744,2746,2749,2751,2753,2755,2758,2760],{"class":1055,"line":2743},72,[1053,2745,2588],{"class":1861},[1053,2747,2748],{"class":1070},"CLIENT_CLASS",[1053,2750,1862],{"class":1861},[1053,2752,1539],{"class":1494},[1053,2754,2317],{"class":1861},[1053,2756,2757],{"class":1070},"django_redis.client.DefaultClient",[1053,2759,1862],{"class":1861},[1053,2761,1981],{"class":1494},[1053,2763,2765],{"class":1055,"line":2764},73,[1053,2766,2623],{"class":1494},[1053,2768,2770],{"class":1055,"line":2769},74,[1053,2771,2629],{"class":1494},[1053,2773,2775],{"class":1055,"line":2774},75,[1053,2776,2635],{"class":1494},[1053,2778,2780],{"class":1055,"line":2779},76,[1053,2781,1110],{"emptyLinePlaceholder":1109},[1053,2783,2785],{"class":1055,"line":2784},77,[1053,2786,2787],{"class":1059},"# REST Framework\n",[1053,2789,2791,2794,2796],{"class":1055,"line":2790},78,[1053,2792,2793],{"class":1490},"REST_FRAMEWORK",[1053,2795,1810],{"class":1494},[1053,2797,2345],{"class":1494},[1053,2799,2801,2803,2806,2808,2810],{"class":1055,"line":2800},79,[1053,2802,1973],{"class":1861},[1053,2804,2805],{"class":1070},"DEFAULT_AUTHENTICATION_CLASSES",[1053,2807,1862],{"class":1861},[1053,2809,1539],{"class":1494},[1053,2811,1968],{"class":1494},[1053,2813,2815,2817,2820,2822],{"class":1055,"line":2814},80,[1053,2816,2365],{"class":1861},[1053,2818,2819],{"class":1070},"rest_framework.authentication.TokenAuthentication",[1053,2821,1862],{"class":1861},[1053,2823,1981],{"class":1494},[1053,2825,2827],{"class":1055,"line":2826},81,[1053,2828,2829],{"class":1494},"    ],\n",[1053,2831,2833,2835,2838,2840,2842],{"class":1055,"line":2832},82,[1053,2834,1973],{"class":1861},[1053,2836,2837],{"class":1070},"DEFAULT_PERMISSION_CLASSES",[1053,2839,1862],{"class":1861},[1053,2841,1539],{"class":1494},[1053,2843,1968],{"class":1494},[1053,2845,2847,2849,2852,2854],{"class":1055,"line":2846},83,[1053,2848,2365],{"class":1861},[1053,2850,2851],{"class":1070},"rest_framework.permissions.IsAuthenticated",[1053,2853,1862],{"class":1861},[1053,2855,1981],{"class":1494},[1053,2857,2859],{"class":1055,"line":2858},84,[1053,2860,2829],{"class":1494},[1053,2862,2864,2866,2869,2871,2873,2875,2878,2880],{"class":1055,"line":2863},85,[1053,2865,1973],{"class":1861},[1053,2867,2868],{"class":1070},"DEFAULT_PAGINATION_CLASS",[1053,2870,1862],{"class":1861},[1053,2872,1539],{"class":1494},[1053,2874,2317],{"class":1861},[1053,2876,2877],{"class":1070},"rest_framework.pagination.PageNumberPagination",[1053,2879,1862],{"class":1861},[1053,2881,1981],{"class":1494},[1053,2883,2885,2887,2890,2892,2894,2896],{"class":1055,"line":2884},86,[1053,2886,1973],{"class":1861},[1053,2888,2889],{"class":1070},"PAGE_SIZE",[1053,2891,1862],{"class":1861},[1053,2893,1539],{"class":1494},[1053,2895,2598],{"class":1561},[1053,2897,1981],{"class":1494},[1053,2899,2901,2903,2906,2908,2910],{"class":1055,"line":2900},87,[1053,2902,1973],{"class":1861},[1053,2904,2905],{"class":1070},"DEFAULT_THROTTLE_CLASSES",[1053,2907,1862],{"class":1861},[1053,2909,1539],{"class":1494},[1053,2911,1968],{"class":1494},[1053,2913,2915,2917,2920,2922],{"class":1055,"line":2914},88,[1053,2916,2365],{"class":1861},[1053,2918,2919],{"class":1070},"rest_framework.throttling.AnonRateThrottle",[1053,2921,1862],{"class":1861},[1053,2923,1981],{"class":1494},[1053,2925,2927,2929,2932],{"class":1055,"line":2926},89,[1053,2928,2365],{"class":1861},[1053,2930,2931],{"class":1070},"rest_framework.throttling.UserRateThrottle",[1053,2933,2323],{"class":1861},[1053,2935,2937],{"class":1055,"line":2936},90,[1053,2938,2829],{"class":1494},[1053,2940,2942,2944,2947,2949,2951],{"class":1055,"line":2941},91,[1053,2943,1973],{"class":1861},[1053,2945,2946],{"class":1070},"DEFAULT_THROTTLE_RATES",[1053,2948,1862],{"class":1861},[1053,2950,1539],{"class":1494},[1053,2952,2345],{"class":1494},[1053,2954,2956,2958,2961,2963,2965,2967,2970,2972],{"class":1055,"line":2955},92,[1053,2957,2365],{"class":1861},[1053,2959,2960],{"class":1070},"anon",[1053,2962,1862],{"class":1861},[1053,2964,1539],{"class":1494},[1053,2966,2317],{"class":1861},[1053,2968,2969],{"class":1070},"100/hour",[1053,2971,1862],{"class":1861},[1053,2973,1981],{"class":1494},[1053,2975,2977,2979,2982,2984,2986,2988,2991],{"class":1055,"line":2976},93,[1053,2978,2365],{"class":1861},[1053,2980,2981],{"class":1070},"user",[1053,2983,1862],{"class":1861},[1053,2985,1539],{"class":1494},[1053,2987,2317],{"class":1861},[1053,2989,2990],{"class":1070},"1000/hour",[1053,2992,2323],{"class":1861},[1053,2994,2996],{"class":1055,"line":2995},94,[1053,2997,2629],{"class":1494},[1053,2999,3001],{"class":1055,"line":3000},95,[1053,3002,2635],{"class":1494},[1053,3004,3006],{"class":1055,"line":3005},96,[1053,3007,1110],{"emptyLinePlaceholder":1109},[1053,3009,3011],{"class":1055,"line":3010},97,[1053,3012,3013],{"class":1059},"# CORS\n",[1053,3015,3017,3019,3021,3023,3025,3027,3029,3031,3033,3035,3037,3039,3041,3043,3045,3047,3049,3051],{"class":1055,"line":3016},98,[1053,3018,1715],{"class":1490},[1053,3020,1810],{"class":1494},[1053,3022,1856],{"class":1813},[1053,3024,1817],{"class":1494},[1053,3026,1862],{"class":1861},[1053,3028,1715],{"class":1070},[1053,3030,1862],{"class":1861},[1053,3032,1682],{"class":1494},[1053,3034,1891],{"class":1890},[1053,3036,1495],{"class":1494},[1053,3038,1934],{"class":1861},[1053,3040,1824],{"class":1494},[1053,3042,1939],{"class":1813},[1053,3044,1817],{"class":1494},[1053,3046,1862],{"class":1861},[1053,3048,1682],{"class":1070},[1053,3050,1862],{"class":1861},[1053,3052,1869],{"class":1494},[1053,3054,3056,3059,3061],{"class":1055,"line":3055},99,[1053,3057,3058],{"class":1490},"CORS_ALLOW_CREDENTIALS",[1053,3060,1810],{"class":1494},[1053,3062,3063],{"class":1498}," True\n",[1053,3065,3067],{"class":1055,"line":3066},100,[1053,3068,1110],{"emptyLinePlaceholder":1109},[1053,3070,3072],{"class":1055,"line":3071},101,[1053,3073,3074],{"class":1059},"# Logging\n",[1053,3076,3078,3081,3083],{"class":1055,"line":3077},102,[1053,3079,3080],{"class":1490},"LOGGING",[1053,3082,1810],{"class":1494},[1053,3084,2345],{"class":1494},[1053,3086,3088,3090,3093,3095,3097,3100],{"class":1055,"line":3087},103,[1053,3089,1973],{"class":1861},[1053,3091,3092],{"class":1070},"version",[1053,3094,1862],{"class":1861},[1053,3096,1539],{"class":1494},[1053,3098,3099],{"class":1561}," 1",[1053,3101,1981],{"class":1494},[1053,3103,3105,3107,3110,3112,3114,3117],{"class":1055,"line":3104},104,[1053,3106,1973],{"class":1861},[1053,3108,3109],{"class":1070},"disable_existing_loggers",[1053,3111,1862],{"class":1861},[1053,3113,1539],{"class":1494},[1053,3115,3116],{"class":1498}," False",[1053,3118,1981],{"class":1494},[1053,3120,3122,3124,3127,3129,3131],{"class":1055,"line":3121},105,[1053,3123,1973],{"class":1861},[1053,3125,3126],{"class":1070},"formatters",[1053,3128,1862],{"class":1861},[1053,3130,1539],{"class":1494},[1053,3132,2345],{"class":1494},[1053,3134,3136,3138,3141,3143,3145],{"class":1055,"line":3135},106,[1053,3137,2365],{"class":1861},[1053,3139,3140],{"class":1070},"verbose",[1053,3142,1862],{"class":1861},[1053,3144,1539],{"class":1494},[1053,3146,2345],{"class":1494},[1053,3148,3150,3152,3155,3157,3159,3161,3165,3168,3171,3174,3178,3181,3184,3186,3188,3191,3193],{"class":1055,"line":3149},107,[1053,3151,2588],{"class":1861},[1053,3153,3154],{"class":1070},"format",[1053,3156,1862],{"class":1861},[1053,3158,1539],{"class":1494},[1053,3160,2317],{"class":1861},[1053,3162,3164],{"class":3163},"s3h35","{levelname}",[1053,3166,3167],{"class":3163}," {asctime}",[1053,3169,3170],{"class":3163}," {module}",[1053,3172,3173],{"class":3163}," {process",[1053,3175,3177],{"class":3176},"s5Kfy",":d",[1053,3179,3180],{"class":3163},"}",[1053,3182,3183],{"class":3163}," {thread",[1053,3185,3177],{"class":3176},[1053,3187,3180],{"class":3163},[1053,3189,3190],{"class":3163}," {message}",[1053,3192,1862],{"class":1861},[1053,3194,1981],{"class":1494},[1053,3196,3198,3200,3203,3205,3207,3209,3212,3214],{"class":1055,"line":3197},108,[1053,3199,2588],{"class":1861},[1053,3201,3202],{"class":1070},"style",[1053,3204,1862],{"class":1861},[1053,3206,1539],{"class":1494},[1053,3208,2317],{"class":1861},[1053,3210,3211],{"class":1070},"{",[1053,3213,1862],{"class":1861},[1053,3215,1981],{"class":1494},[1053,3217,3219],{"class":1055,"line":3218},109,[1053,3220,3221],{"class":1494},"        },\n",[1053,3223,3225,3227,3230,3232,3234],{"class":1055,"line":3224},110,[1053,3226,2365],{"class":1861},[1053,3228,3229],{"class":1070},"simple",[1053,3231,1862],{"class":1861},[1053,3233,1539],{"class":1494},[1053,3235,2345],{"class":1494},[1053,3237,3239,3241,3243,3245,3247,3249,3251,3253,3255],{"class":1055,"line":3238},111,[1053,3240,2588],{"class":1861},[1053,3242,3154],{"class":1070},[1053,3244,1862],{"class":1861},[1053,3246,1539],{"class":1494},[1053,3248,2317],{"class":1861},[1053,3250,3164],{"class":3163},[1053,3252,3190],{"class":3163},[1053,3254,1862],{"class":1861},[1053,3256,1981],{"class":1494},[1053,3258,3260,3262,3264,3266,3268,3270,3272,3274],{"class":1055,"line":3259},112,[1053,3261,2588],{"class":1861},[1053,3263,3202],{"class":1070},[1053,3265,1862],{"class":1861},[1053,3267,1539],{"class":1494},[1053,3269,2317],{"class":1861},[1053,3271,3211],{"class":1070},[1053,3273,1862],{"class":1861},[1053,3275,1981],{"class":1494},[1053,3277,3279],{"class":1055,"line":3278},113,[1053,3280,3221],{"class":1494},[1053,3282,3284],{"class":1055,"line":3283},114,[1053,3285,3286],{"class":1494},"    },\n",[1053,3288,3290,3292,3295,3297,3299],{"class":1055,"line":3289},115,[1053,3291,1973],{"class":1861},[1053,3293,3294],{"class":1070},"handlers",[1053,3296,1862],{"class":1861},[1053,3298,1539],{"class":1494},[1053,3300,2345],{"class":1494},[1053,3302,3304,3306,3309,3311,3313],{"class":1055,"line":3303},116,[1053,3305,2365],{"class":1861},[1053,3307,3308],{"class":1070},"file",[1053,3310,1862],{"class":1861},[1053,3312,1539],{"class":1494},[1053,3314,2345],{"class":1494},[1053,3316,3318,3320,3323,3325,3327,3329,3332,3334],{"class":1055,"line":3317},117,[1053,3319,2588],{"class":1861},[1053,3321,3322],{"class":1070},"level",[1053,3324,1862],{"class":1861},[1053,3326,1539],{"class":1494},[1053,3328,2317],{"class":1861},[1053,3330,3331],{"class":1070},"INFO",[1053,3333,1862],{"class":1861},[1053,3335,1981],{"class":1494},[1053,3337,3339,3341,3344,3346,3348,3350,3353,3355],{"class":1055,"line":3338},118,[1053,3340,2588],{"class":1861},[1053,3342,3343],{"class":1070},"class",[1053,3345,1862],{"class":1861},[1053,3347,1539],{"class":1494},[1053,3349,2317],{"class":1861},[1053,3351,3352],{"class":1070},"logging.FileHandler",[1053,3354,1862],{"class":1861},[1053,3356,1981],{"class":1494},[1053,3358,3360,3362,3365,3367,3369,3371,3374,3376],{"class":1055,"line":3359},119,[1053,3361,2588],{"class":1861},[1053,3363,3364],{"class":1070},"filename",[1053,3366,1862],{"class":1861},[1053,3368,1539],{"class":1494},[1053,3370,2317],{"class":1861},[1053,3372,3373],{"class":1070},"user_service.log",[1053,3375,1862],{"class":1861},[1053,3377,1981],{"class":1494},[1053,3379,3381,3383,3386,3388,3390,3392,3394,3396],{"class":1055,"line":3380},120,[1053,3382,2588],{"class":1861},[1053,3384,3385],{"class":1070},"formatter",[1053,3387,1862],{"class":1861},[1053,3389,1539],{"class":1494},[1053,3391,2317],{"class":1861},[1053,3393,3140],{"class":1070},[1053,3395,1862],{"class":1861},[1053,3397,1981],{"class":1494},[1053,3399,3401],{"class":1055,"line":3400},121,[1053,3402,3221],{"class":1494},[1053,3404,3406,3408,3411,3413,3415],{"class":1055,"line":3405},122,[1053,3407,2365],{"class":1861},[1053,3409,3410],{"class":1070},"console",[1053,3412,1862],{"class":1861},[1053,3414,1539],{"class":1494},[1053,3416,2345],{"class":1494},[1053,3418,3420,3422,3424,3426,3428,3430,3432,3434],{"class":1055,"line":3419},123,[1053,3421,2588],{"class":1861},[1053,3423,3322],{"class":1070},[1053,3425,1862],{"class":1861},[1053,3427,1539],{"class":1494},[1053,3429,2317],{"class":1861},[1053,3431,1491],{"class":1070},[1053,3433,1862],{"class":1861},[1053,3435,1981],{"class":1494},[1053,3437,3439,3441,3443,3445,3447,3449,3452,3454],{"class":1055,"line":3438},124,[1053,3440,2588],{"class":1861},[1053,3442,3343],{"class":1070},[1053,3444,1862],{"class":1861},[1053,3446,1539],{"class":1494},[1053,3448,2317],{"class":1861},[1053,3450,3451],{"class":1070},"logging.StreamHandler",[1053,3453,1862],{"class":1861},[1053,3455,1981],{"class":1494},[1053,3457,3459,3461,3463,3465,3467,3469,3471,3473],{"class":1055,"line":3458},125,[1053,3460,2588],{"class":1861},[1053,3462,3385],{"class":1070},[1053,3464,1862],{"class":1861},[1053,3466,1539],{"class":1494},[1053,3468,2317],{"class":1861},[1053,3470,3229],{"class":1070},[1053,3472,1862],{"class":1861},[1053,3474,1981],{"class":1494},[1053,3476,3478],{"class":1055,"line":3477},126,[1053,3479,3221],{"class":1494},[1053,3481,3483],{"class":1055,"line":3482},127,[1053,3484,3286],{"class":1494},[1053,3486,3488,3490,3493,3495,3497],{"class":1055,"line":3487},128,[1053,3489,1973],{"class":1861},[1053,3491,3492],{"class":1070},"root",[1053,3494,1862],{"class":1861},[1053,3496,1539],{"class":1494},[1053,3498,2345],{"class":1494},[1053,3500,3502,3504,3506,3508,3510,3513,3515,3517,3519,3521,3523,3525,3527],{"class":1055,"line":3501},129,[1053,3503,2365],{"class":1861},[1053,3505,3294],{"class":1070},[1053,3507,1862],{"class":1861},[1053,3509,1539],{"class":1494},[1053,3511,3512],{"class":1494}," [",[1053,3514,1862],{"class":1861},[1053,3516,3410],{"class":1070},[1053,3518,1862],{"class":1861},[1053,3520,1682],{"class":1494},[1053,3522,2317],{"class":1861},[1053,3524,3308],{"class":1070},[1053,3526,1862],{"class":1861},[1053,3528,3529],{"class":1494},"],\n",[1053,3531,3533,3535,3537,3539,3541,3543,3545,3547],{"class":1055,"line":3532},130,[1053,3534,2365],{"class":1861},[1053,3536,3322],{"class":1070},[1053,3538,1862],{"class":1861},[1053,3540,1539],{"class":1494},[1053,3542,2317],{"class":1861},[1053,3544,3331],{"class":1070},[1053,3546,1862],{"class":1861},[1053,3548,1981],{"class":1494},[1053,3550,3552],{"class":1055,"line":3551},131,[1053,3553,3286],{"class":1494},[1053,3555,3557],{"class":1055,"line":3556},132,[1053,3558,2635],{"class":1494},[1053,3560,3562],{"class":1055,"line":3561},133,[1053,3563,1110],{"emptyLinePlaceholder":1109},[1053,3565,3567],{"class":1055,"line":3566},134,[1053,3568,3569],{"class":1059},"# Service-specific settings\n",[1053,3571,3573,3576,3578,3580,3583],{"class":1055,"line":3572},135,[1053,3574,3575],{"class":1490},"SERVICE_NAME",[1053,3577,1810],{"class":1494},[1053,3579,2317],{"class":1861},[1053,3581,3582],{"class":1070},"user-service",[1053,3584,2323],{"class":1861},[1053,3586,3588,3591,3593,3595,3598],{"class":1055,"line":3587},136,[1053,3589,3590],{"class":1490},"SERVICE_VERSION",[1053,3592,1810],{"class":1494},[1053,3594,2317],{"class":1861},[1053,3596,3597],{"class":1070},"1.0.0",[1053,3599,2323],{"class":1861},[1053,3601,3603,3605,3607,3609,3611,3613,3615,3617],{"class":1055,"line":3602},137,[1053,3604,1652],{"class":1490},[1053,3606,1810],{"class":1494},[1053,3608,1856],{"class":1813},[1053,3610,1817],{"class":1494},[1053,3612,1862],{"class":1861},[1053,3614,1652],{"class":1070},[1053,3616,1862],{"class":1861},[1053,3618,1869],{"class":1494},[1053,3620,3622,3624,3626,3628,3630,3632,3634,3636,3638,3640,3642,3644,3646,3648],{"class":1055,"line":3621},138,[1053,3623,1632],{"class":1490},[1053,3625,1810],{"class":1494},[1053,3627,1856],{"class":1813},[1053,3629,1817],{"class":1494},[1053,3631,1862],{"class":1861},[1053,3633,1632],{"class":1070},[1053,3635,1862],{"class":1861},[1053,3637,1682],{"class":1494},[1053,3639,1891],{"class":1890},[1053,3641,1495],{"class":1494},[1053,3643,1862],{"class":1861},[1053,3645,1556],{"class":1070},[1053,3647,1862],{"class":1861},[1053,3649,1869],{"class":1494},[1053,3651,3653,3655,3657,3659,3661,3663,3665,3667,3669,3671,3673,3676,3678,3680,3682,3685],{"class":1055,"line":3652},139,[1053,3654,1642],{"class":1490},[1053,3656,1810],{"class":1494},[1053,3658,1856],{"class":1813},[1053,3660,1817],{"class":1494},[1053,3662,1862],{"class":1861},[1053,3664,1642],{"class":1070},[1053,3666,1862],{"class":1861},[1053,3668,1682],{"class":1494},[1053,3670,1891],{"class":1890},[1053,3672,1495],{"class":1494},[1053,3674,3675],{"class":1561},"8500",[1053,3677,1682],{"class":1494},[1053,3679,1901],{"class":1890},[1053,3681,1495],{"class":1494},[1053,3683,3684],{"class":1906},"int",[1053,3686,1869],{"class":1494},[1053,3688,3690,3692,3694,3696,3698,3700,3702,3704,3706,3708,3710,3712,3715,3717],{"class":1055,"line":3689},140,[1053,3691,1599],{"class":1490},[1053,3693,1810],{"class":1494},[1053,3695,1856],{"class":1813},[1053,3697,1817],{"class":1494},[1053,3699,1862],{"class":1861},[1053,3701,1599],{"class":1070},[1053,3703,1862],{"class":1861},[1053,3705,1682],{"class":1494},[1053,3707,1891],{"class":1890},[1053,3709,1495],{"class":1494},[1053,3711,1862],{"class":1861},[1053,3713,3714],{"class":1070},"amqp://localhost:5672/",[1053,3716,1862],{"class":1861},[1053,3718,1869],{"class":1494},[1030,3720,3722],{"id":3721},"docker-development-environment","Docker Development Environment",[1035,3724,3726],{"id":3725},"_1-service-dockerfile","1. Service Dockerfile",[1043,3728,3732],{"className":3729,"code":3730,"language":3731,"meta":1048,"style":1048},"language-dockerfile shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","# services/user-service/Dockerfile\nFROM python:3.11-slim\n\n# Set environment variables\nENV PYTHONDONTWRITEBYTECODE=1\nENV PYTHONUNBUFFERED=1\n\n# Set work directory\nWORKDIR /app\n\n# Install system dependencies\nRUN apt-get update \\\n    && apt-get install -y --no-install-recommends \\\n        postgresql-client \\\n        gcc \\\n        python3-dev \\\n        libpq-dev \\\n    && rm -rf /var/lib/apt/lists/*\n\n# Install Python dependencies\nCOPY requirements.txt /app/\nRUN pip install --no-cache-dir -r requirements.txt\n\n# Copy project\nCOPY . /app/\n\n# Create non-root user\nRUN adduser --disabled-password --gecos '' appuser\nRUN chown -R appuser:appuser /app\nUSER appuser\n\n# Expose port\nEXPOSE 8000\n\n# Health check\nHEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \\\n    CMD curl -f http://localhost:8000/health/ || exit 1\n\n# Run the application\nCMD [\"gunicorn\", \"--bind\", \"0.0.0.0:8000\", \"--workers\", \"3\", \"user_service.wsgi:application\"]\n","dockerfile",[1050,3733,3734,3739,3748,3752,3757,3765,3772,3776,3781,3789,3793,3798,3806,3811,3816,3821,3826,3831,3836,3840,3845,3853,3860,3864,3869,3876,3880,3885,3897,3904,3910,3914,3919,3927,3931,3936,3944,3952,3956,3961],{"__ignoreMap":1048},[1053,3735,3736],{"class":1055,"line":1056},[1053,3737,3738],{"class":1059},"# services/user-service/Dockerfile\n",[1053,3740,3741,3745],{"class":1055,"line":1063},[1053,3742,3744],{"class":3743},"scgAs","FROM",[1053,3746,3747],{"class":1509}," python:3.11-slim\n",[1053,3749,3750],{"class":1055,"line":1080},[1053,3751,1110],{"emptyLinePlaceholder":1109},[1053,3753,3754],{"class":1055,"line":1086},[1053,3755,3756],{"class":1059},"# Set environment variables\n",[1053,3758,3759,3762],{"class":1055,"line":1106},[1053,3760,3761],{"class":3743},"ENV",[1053,3763,3764],{"class":1509}," PYTHONDONTWRITEBYTECODE=1\n",[1053,3766,3767,3769],{"class":1055,"line":1113},[1053,3768,3761],{"class":3743},[1053,3770,3771],{"class":1509}," PYTHONUNBUFFERED=1\n",[1053,3773,3774],{"class":1055,"line":1119},[1053,3775,1110],{"emptyLinePlaceholder":1109},[1053,3777,3778],{"class":1055,"line":1134},[1053,3779,3780],{"class":1059},"# Set work directory\n",[1053,3782,3783,3786],{"class":1055,"line":1140},[1053,3784,3785],{"class":3743},"WORKDIR",[1053,3787,3788],{"class":1509}," /app\n",[1053,3790,3791],{"class":1055,"line":1145},[1053,3792,1110],{"emptyLinePlaceholder":1109},[1053,3794,3795],{"class":1055,"line":1151},[1053,3796,3797],{"class":1059},"# Install system dependencies\n",[1053,3799,3800,3803],{"class":1055,"line":1163},[1053,3801,3802],{"class":3743},"RUN",[1053,3804,3805],{"class":1509}," apt-get update \\\n",[1053,3807,3808],{"class":1055,"line":1168},[1053,3809,3810],{"class":1509},"    && apt-get install -y --no-install-recommends \\\n",[1053,3812,3813],{"class":1055,"line":1181},[1053,3814,3815],{"class":1509},"        postgresql-client \\\n",[1053,3817,3818],{"class":1055,"line":1186},[1053,3819,3820],{"class":1509},"        gcc \\\n",[1053,3822,3823],{"class":1055,"line":1192},[1053,3824,3825],{"class":1509},"        python3-dev \\\n",[1053,3827,3828],{"class":1055,"line":1995},[1053,3829,3830],{"class":1509},"        libpq-dev \\\n",[1053,3832,3833],{"class":1055,"line":2007},[1053,3834,3835],{"class":1509},"    && rm -rf /var/lib/apt/lists/*\n",[1053,3837,3838],{"class":1055,"line":2019},[1053,3839,1110],{"emptyLinePlaceholder":1109},[1053,3841,3842],{"class":1055,"line":2031},[1053,3843,3844],{"class":1059},"# Install Python dependencies\n",[1053,3846,3847,3850],{"class":1055,"line":2043},[1053,3848,3849],{"class":3743},"COPY",[1053,3851,3852],{"class":1509}," requirements.txt /app/\n",[1053,3854,3855,3857],{"class":1055,"line":2049},[1053,3856,3802],{"class":3743},[1053,3858,3859],{"class":1509}," pip install --no-cache-dir -r requirements.txt\n",[1053,3861,3862],{"class":1055,"line":2054},[1053,3863,1110],{"emptyLinePlaceholder":1109},[1053,3865,3866],{"class":1055,"line":2064},[1053,3867,3868],{"class":1059},"# Copy project\n",[1053,3870,3871,3873],{"class":1055,"line":2076},[1053,3872,3849],{"class":3743},[1053,3874,3875],{"class":1509}," . /app/\n",[1053,3877,3878],{"class":1055,"line":2088},[1053,3879,1110],{"emptyLinePlaceholder":1109},[1053,3881,3882],{"class":1055,"line":2100},[1053,3883,3884],{"class":1059},"# Create non-root user\n",[1053,3886,3887,3889,3892,3894],{"class":1055,"line":2105},[1053,3888,3802],{"class":3743},[1053,3890,3891],{"class":1509}," adduser --disabled-password --gecos ",[1053,3893,1934],{"class":1070},[1053,3895,3896],{"class":1509}," appuser\n",[1053,3898,3899,3901],{"class":1055,"line":2110},[1053,3900,3802],{"class":3743},[1053,3902,3903],{"class":1509}," chown -R appuser:appuser /app\n",[1053,3905,3906,3908],{"class":1055,"line":2120},[1053,3907,2428],{"class":3743},[1053,3909,3896],{"class":1509},[1053,3911,3912],{"class":1055,"line":2132},[1053,3913,1110],{"emptyLinePlaceholder":1109},[1053,3915,3916],{"class":1055,"line":2137},[1053,3917,3918],{"class":1059},"# Expose port\n",[1053,3920,3921,3924],{"class":1055,"line":2142},[1053,3922,3923],{"class":3743},"EXPOSE",[1053,3925,3926],{"class":1509}," 8000\n",[1053,3928,3929],{"class":1055,"line":2164},[1053,3930,1110],{"emptyLinePlaceholder":1109},[1053,3932,3933],{"class":1055,"line":2169},[1053,3934,3935],{"class":1059},"# Health check\n",[1053,3937,3938,3941],{"class":1055,"line":2179},[1053,3939,3940],{"class":3743},"HEALTHCHECK",[1053,3942,3943],{"class":1509}," --interval=30s --timeout=30s --start-period=5s --retries=3 \\\n",[1053,3945,3946,3949],{"class":1055,"line":2191},[1053,3947,3948],{"class":3743},"    CMD",[1053,3950,3951],{"class":1509}," curl -f http://localhost:8000/health/ || exit 1\n",[1053,3953,3954],{"class":1055,"line":2203},[1053,3955,1110],{"emptyLinePlaceholder":1109},[1053,3957,3958],{"class":1055,"line":2215},[1053,3959,3960],{"class":1059},"# Run the application\n",[1053,3962,3963,3966,3968,3971,3974,3977,3979,3982,3984,3987,3989,3992,3994,3997],{"class":1055,"line":2227},[1053,3964,3965],{"class":3743},"CMD",[1053,3967,3512],{"class":1509},[1053,3969,3970],{"class":1070},"\"gunicorn\"",[1053,3972,3973],{"class":1509},", ",[1053,3975,3976],{"class":1070},"\"--bind\"",[1053,3978,3973],{"class":1509},[1053,3980,3981],{"class":1070},"\"0.0.0.0:8000\"",[1053,3983,3973],{"class":1509},[1053,3985,3986],{"class":1070},"\"--workers\"",[1053,3988,3973],{"class":1509},[1053,3990,3991],{"class":1070},"\"3\"",[1053,3993,3973],{"class":1509},[1053,3995,3996],{"class":1070},"\"user_service.wsgi:application\"",[1053,3998,2046],{"class":1509},[1035,4000,4002],{"id":4001},"_2-development-docker-compose","2. Development Docker Compose",[1043,4004,4008],{"className":4005,"code":4006,"language":4007,"meta":1048,"style":1048},"language-yaml shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","# docker-compose.yml\nversion: '3.8'\n\nservices:\n  # Infrastructure Services\n  postgres:\n    image: postgres:15-alpine\n    environment:\n      POSTGRES_DB: microservices_db\n      POSTGRES_USER: postgres\n      POSTGRES_PASSWORD: password\n    volumes:\n      - postgres_data:/var/lib/postgresql/data\n      - ./infrastructure/docker/postgres/init.sql:/docker-entrypoint-initdb.d/init.sql\n    ports:\n      - \"5432:5432\"\n    healthcheck:\n      test: [\"CMD-SHELL\", \"pg_isready -U postgres\"]\n      interval: 10s\n      timeout: 5s\n      retries: 5\n\n  redis:\n    image: redis:7-alpine\n    command: redis-server --appendonly yes\n    volumes:\n      - redis_data:/data\n    ports:\n      - \"6379:6379\"\n    healthcheck:\n      test: [\"CMD\", \"redis-cli\", \"ping\"]\n      interval: 10s\n      timeout: 5s\n      retries: 5\n\n  rabbitmq:\n    image: rabbitmq:3-management-alpine\n    environment:\n      RABBITMQ_DEFAULT_USER: admin\n      RABBITMQ_DEFAULT_PASS: password\n    volumes:\n      - rabbitmq_data:/var/lib/rabbitmq\n    ports:\n      - \"5672:5672\"\n      - \"15672:15672\"\n    healthcheck:\n      test: [\"CMD\", \"rabbitmq-diagnostics\", \"ping\"]\n      interval: 30s\n      timeout: 10s\n      retries: 5\n\n  consul:\n    image: consul:1.15\n    command: consul agent -dev -client=0.0.0.0 -ui\n    ports:\n      - \"8500:8500\"\n    volumes:\n      - consul_data:/consul/data\n\n  # Microservices\n  user-service:\n    build: ./services/user-service\n    environment:\n      - DEBUG=1\n      - DB_HOST=postgres\n      - DB_NAME=user_service_db\n      - DB_USER=postgres\n      - DB_PASSWORD=password\n      - REDIS_URL=redis://redis:6379/0\n      - RABBITMQ_URL=amqp://admin:password@rabbitmq:5672/\n      - CONSUL_HOST=consul\n    ports:\n      - \"8001:8000\"\n    depends_on:\n      postgres:\n        condition: service_healthy\n      redis:\n        condition: service_healthy\n      rabbitmq:\n        condition: service_healthy\n    volumes:\n      - ./services/user-service:/app\n    command: >\n      sh -c \"python manage.py migrate &&\n             python manage.py runserver 0.0.0.0:8000\"\n\n  product-service:\n    build: ./services/product-service\n    environment:\n      - DEBUG=1\n      - DB_HOST=postgres\n      - DB_NAME=product_service_db\n      - DB_USER=postgres\n      - DB_PASSWORD=password\n      - REDIS_URL=redis://redis:6379/1\n      - RABBITMQ_URL=amqp://admin:password@rabbitmq:5672/\n      - CONSUL_HOST=consul\n    ports:\n      - \"8002:8000\"\n    depends_on:\n      postgres:\n        condition: service_healthy\n      redis:\n        condition: service_healthy\n      rabbitmq:\n        condition: service_healthy\n    volumes:\n      - ./services/product-service:/app\n\n  order-service:\n    build: ./services/order-service\n    environment:\n      - DEBUG=1\n      - DB_HOST=postgres\n      - DB_NAME=order_service_db\n      - DB_USER=postgres\n      - DB_PASSWORD=password\n      - REDIS_URL=redis://redis:6379/2\n      - RABBITMQ_URL=amqp://admin:password@rabbitmq:5672/\n      - CONSUL_HOST=consul\n    ports:\n      - \"8003:8000\"\n    depends_on:\n      postgres:\n        condition: service_healthy\n      redis:\n        condition: service_healthy\n      rabbitmq:\n        condition: service_healthy\n    volumes:\n      - ./services/order-service:/app\n\n  # API Gateway\n  kong:\n    image: kong:3.4\n    environment:\n      KONG_DATABASE: \"off\"\n      KONG_DECLARATIVE_CONFIG: /kong/declarative/kong.yml\n      KONG_PROXY_ACCESS_LOG: /dev/stdout\n      KONG_ADMIN_ACCESS_LOG: /dev/stdout\n      KONG_PROXY_ERROR_LOG: /dev/stderr\n      KONG_ADMIN_ERROR_LOG: /dev/stderr\n      KONG_ADMIN_LISTEN: 0.0.0.0:8001\n    volumes:\n      - ./infrastructure/docker/kong/kong.yml:/kong/declarative/kong.yml\n    ports:\n      - \"8000:8000\"\n      - \"8444:8444\"\n    depends_on:\n      - user-service\n      - product-service\n      - order-service\n\nvolumes:\n  postgres_data:\n  redis_data:\n  rabbitmq_data:\n  consul_data:\n","yaml",[1050,4009,4010,4015,4029,4033,4041,4046,4053,4063,4070,4080,4090,4100,4107,4115,4122,4129,4142,4149,4177,4187,4197,4207,4211,4218,4227,4237,4243,4250,4256,4267,4273,4307,4315,4323,4331,4335,4342,4351,4357,4367,4376,4382,4389,4395,4406,4417,4423,4456,4465,4473,4481,4485,4492,4501,4510,4516,4527,4533,4540,4544,4549,4556,4566,4572,4579,4586,4593,4600,4607,4614,4621,4628,4634,4645,4652,4659,4669,4676,4684,4691,4699,4705,4712,4721,4726,4731,4735,4742,4751,4757,4763,4769,4776,4782,4788,4795,4801,4807,4813,4824,4830,4836,4844,4850,4858,4864,4872,4878,4885,4889,4896,4905,4911,4917,4923,4930,4936,4942,4949,4955,4961,4967,4978,4984,4990,4998,5004,5012,5018,5026,5032,5039,5043,5048,5055,5064,5070,5084,5094,5104,5113,5124,5134,5145,5152,5160,5167,5179,5191,5198,5206,5214,5222,5227,5235,5243,5251,5259],{"__ignoreMap":1048},[1053,4011,4012],{"class":1055,"line":1056},[1053,4013,4014],{"class":1059},"# docker-compose.yml\n",[1053,4016,4017,4020,4022,4024,4027],{"class":1055,"line":1063},[1053,4018,3092],{"class":4019},"suXOh",[1053,4021,1539],{"class":1494},[1053,4023,2317],{"class":1861},[1053,4025,4026],{"class":1070},"3.8",[1053,4028,2323],{"class":1861},[1053,4030,4031],{"class":1055,"line":1080},[1053,4032,1110],{"emptyLinePlaceholder":1109},[1053,4034,4035,4038],{"class":1055,"line":1086},[1053,4036,4037],{"class":4019},"services",[1053,4039,4040],{"class":1494},":\n",[1053,4042,4043],{"class":1055,"line":1106},[1053,4044,4045],{"class":1059},"  # Infrastructure Services\n",[1053,4047,4048,4051],{"class":1055,"line":1113},[1053,4049,4050],{"class":4019},"  postgres",[1053,4052,4040],{"class":1494},[1053,4054,4055,4058,4060],{"class":1055,"line":1119},[1053,4056,4057],{"class":4019},"    image",[1053,4059,1539],{"class":1494},[1053,4061,4062],{"class":1070}," postgres:15-alpine\n",[1053,4064,4065,4068],{"class":1055,"line":1134},[1053,4066,4067],{"class":4019},"    environment",[1053,4069,4040],{"class":1494},[1053,4071,4072,4075,4077],{"class":1055,"line":1140},[1053,4073,4074],{"class":4019},"      POSTGRES_DB",[1053,4076,1539],{"class":1494},[1053,4078,4079],{"class":1070}," microservices_db\n",[1053,4081,4082,4085,4087],{"class":1055,"line":1145},[1053,4083,4084],{"class":4019},"      POSTGRES_USER",[1053,4086,1539],{"class":1494},[1053,4088,4089],{"class":1070}," postgres\n",[1053,4091,4092,4095,4097],{"class":1055,"line":1151},[1053,4093,4094],{"class":4019},"      POSTGRES_PASSWORD",[1053,4096,1539],{"class":1494},[1053,4098,4099],{"class":1070}," password\n",[1053,4101,4102,4105],{"class":1055,"line":1163},[1053,4103,4104],{"class":4019},"    volumes",[1053,4106,4040],{"class":1494},[1053,4108,4109,4112],{"class":1055,"line":1168},[1053,4110,4111],{"class":1494},"      -",[1053,4113,4114],{"class":1070}," postgres_data:/var/lib/postgresql/data\n",[1053,4116,4117,4119],{"class":1055,"line":1181},[1053,4118,4111],{"class":1494},[1053,4120,4121],{"class":1070}," ./infrastructure/docker/postgres/init.sql:/docker-entrypoint-initdb.d/init.sql\n",[1053,4123,4124,4127],{"class":1055,"line":1186},[1053,4125,4126],{"class":4019},"    ports",[1053,4128,4040],{"class":1494},[1053,4130,4131,4133,4136,4139],{"class":1055,"line":1192},[1053,4132,4111],{"class":1494},[1053,4134,4135],{"class":1861}," \"",[1053,4137,4138],{"class":1070},"5432:5432",[1053,4140,4141],{"class":1861},"\"\n",[1053,4143,4144,4147],{"class":1055,"line":1995},[1053,4145,4146],{"class":4019},"    healthcheck",[1053,4148,4040],{"class":1494},[1053,4150,4151,4154,4156,4158,4161,4164,4166,4168,4170,4173,4175],{"class":1055,"line":2007},[1053,4152,4153],{"class":4019},"      test",[1053,4155,1539],{"class":1494},[1053,4157,3512],{"class":1494},[1053,4159,4160],{"class":1861},"\"",[1053,4162,4163],{"class":1070},"CMD-SHELL",[1053,4165,4160],{"class":1861},[1053,4167,1682],{"class":1494},[1053,4169,4135],{"class":1861},[1053,4171,4172],{"class":1070},"pg_isready -U postgres",[1053,4174,4160],{"class":1861},[1053,4176,2046],{"class":1494},[1053,4178,4179,4182,4184],{"class":1055,"line":2019},[1053,4180,4181],{"class":4019},"      interval",[1053,4183,1539],{"class":1494},[1053,4185,4186],{"class":1070}," 10s\n",[1053,4188,4189,4192,4194],{"class":1055,"line":2031},[1053,4190,4191],{"class":4019},"      timeout",[1053,4193,1539],{"class":1494},[1053,4195,4196],{"class":1070}," 5s\n",[1053,4198,4199,4202,4204],{"class":1055,"line":2043},[1053,4200,4201],{"class":4019},"      retries",[1053,4203,1539],{"class":1494},[1053,4205,4206],{"class":1561}," 5\n",[1053,4208,4209],{"class":1055,"line":2049},[1053,4210,1110],{"emptyLinePlaceholder":1109},[1053,4212,4213,4216],{"class":1055,"line":2054},[1053,4214,4215],{"class":4019},"  redis",[1053,4217,4040],{"class":1494},[1053,4219,4220,4222,4224],{"class":1055,"line":2064},[1053,4221,4057],{"class":4019},[1053,4223,1539],{"class":1494},[1053,4225,4226],{"class":1070}," redis:7-alpine\n",[1053,4228,4229,4232,4234],{"class":1055,"line":2076},[1053,4230,4231],{"class":4019},"    command",[1053,4233,1539],{"class":1494},[1053,4235,4236],{"class":1070}," redis-server --appendonly yes\n",[1053,4238,4239,4241],{"class":1055,"line":2088},[1053,4240,4104],{"class":4019},[1053,4242,4040],{"class":1494},[1053,4244,4245,4247],{"class":1055,"line":2100},[1053,4246,4111],{"class":1494},[1053,4248,4249],{"class":1070}," redis_data:/data\n",[1053,4251,4252,4254],{"class":1055,"line":2105},[1053,4253,4126],{"class":4019},[1053,4255,4040],{"class":1494},[1053,4257,4258,4260,4262,4265],{"class":1055,"line":2110},[1053,4259,4111],{"class":1494},[1053,4261,4135],{"class":1861},[1053,4263,4264],{"class":1070},"6379:6379",[1053,4266,4141],{"class":1861},[1053,4268,4269,4271],{"class":1055,"line":2120},[1053,4270,4146],{"class":4019},[1053,4272,4040],{"class":1494},[1053,4274,4275,4277,4279,4281,4283,4285,4287,4289,4291,4294,4296,4298,4300,4303,4305],{"class":1055,"line":2132},[1053,4276,4153],{"class":4019},[1053,4278,1539],{"class":1494},[1053,4280,3512],{"class":1494},[1053,4282,4160],{"class":1861},[1053,4284,3965],{"class":1070},[1053,4286,4160],{"class":1861},[1053,4288,1682],{"class":1494},[1053,4290,4135],{"class":1861},[1053,4292,4293],{"class":1070},"redis-cli",[1053,4295,4160],{"class":1861},[1053,4297,1682],{"class":1494},[1053,4299,4135],{"class":1861},[1053,4301,4302],{"class":1070},"ping",[1053,4304,4160],{"class":1861},[1053,4306,2046],{"class":1494},[1053,4308,4309,4311,4313],{"class":1055,"line":2137},[1053,4310,4181],{"class":4019},[1053,4312,1539],{"class":1494},[1053,4314,4186],{"class":1070},[1053,4316,4317,4319,4321],{"class":1055,"line":2142},[1053,4318,4191],{"class":4019},[1053,4320,1539],{"class":1494},[1053,4322,4196],{"class":1070},[1053,4324,4325,4327,4329],{"class":1055,"line":2164},[1053,4326,4201],{"class":4019},[1053,4328,1539],{"class":1494},[1053,4330,4206],{"class":1561},[1053,4332,4333],{"class":1055,"line":2169},[1053,4334,1110],{"emptyLinePlaceholder":1109},[1053,4336,4337,4340],{"class":1055,"line":2179},[1053,4338,4339],{"class":4019},"  rabbitmq",[1053,4341,4040],{"class":1494},[1053,4343,4344,4346,4348],{"class":1055,"line":2191},[1053,4345,4057],{"class":4019},[1053,4347,1539],{"class":1494},[1053,4349,4350],{"class":1070}," rabbitmq:3-management-alpine\n",[1053,4352,4353,4355],{"class":1055,"line":2203},[1053,4354,4067],{"class":4019},[1053,4356,4040],{"class":1494},[1053,4358,4359,4362,4364],{"class":1055,"line":2215},[1053,4360,4361],{"class":4019},"      RABBITMQ_DEFAULT_USER",[1053,4363,1539],{"class":1494},[1053,4365,4366],{"class":1070}," admin\n",[1053,4368,4369,4372,4374],{"class":1055,"line":2227},[1053,4370,4371],{"class":4019},"      RABBITMQ_DEFAULT_PASS",[1053,4373,1539],{"class":1494},[1053,4375,4099],{"class":1070},[1053,4377,4378,4380],{"class":1055,"line":2239},[1053,4379,4104],{"class":4019},[1053,4381,4040],{"class":1494},[1053,4383,4384,4386],{"class":1055,"line":2251},[1053,4385,4111],{"class":1494},[1053,4387,4388],{"class":1070}," rabbitmq_data:/var/lib/rabbitmq\n",[1053,4390,4391,4393],{"class":1055,"line":2263},[1053,4392,4126],{"class":4019},[1053,4394,4040],{"class":1494},[1053,4396,4397,4399,4401,4404],{"class":1055,"line":2275},[1053,4398,4111],{"class":1494},[1053,4400,4135],{"class":1861},[1053,4402,4403],{"class":1070},"5672:5672",[1053,4405,4141],{"class":1861},[1053,4407,4408,4410,4412,4415],{"class":1055,"line":2287},[1053,4409,4111],{"class":1494},[1053,4411,4135],{"class":1861},[1053,4413,4414],{"class":1070},"15672:15672",[1053,4416,4141],{"class":1861},[1053,4418,4419,4421],{"class":1055,"line":2299},[1053,4420,4146],{"class":4019},[1053,4422,4040],{"class":1494},[1053,4424,4425,4427,4429,4431,4433,4435,4437,4439,4441,4444,4446,4448,4450,4452,4454],{"class":1055,"line":2304},[1053,4426,4153],{"class":4019},[1053,4428,1539],{"class":1494},[1053,4430,3512],{"class":1494},[1053,4432,4160],{"class":1861},[1053,4434,3965],{"class":1070},[1053,4436,4160],{"class":1861},[1053,4438,1682],{"class":1494},[1053,4440,4135],{"class":1861},[1053,4442,4443],{"class":1070},"rabbitmq-diagnostics",[1053,4445,4160],{"class":1861},[1053,4447,1682],{"class":1494},[1053,4449,4135],{"class":1861},[1053,4451,4302],{"class":1070},[1053,4453,4160],{"class":1861},[1053,4455,2046],{"class":1494},[1053,4457,4458,4460,4462],{"class":1055,"line":2309},[1053,4459,4181],{"class":4019},[1053,4461,1539],{"class":1494},[1053,4463,4464],{"class":1070}," 30s\n",[1053,4466,4467,4469,4471],{"class":1055,"line":2326},[1053,4468,4191],{"class":4019},[1053,4470,1539],{"class":1494},[1053,4472,4186],{"class":1070},[1053,4474,4475,4477,4479],{"class":1055,"line":2331},[1053,4476,4201],{"class":4019},[1053,4478,1539],{"class":1494},[1053,4480,4206],{"class":1561},[1053,4482,4483],{"class":1055,"line":2337},[1053,4484,1110],{"emptyLinePlaceholder":1109},[1053,4486,4487,4490],{"class":1055,"line":2348},[1053,4488,4489],{"class":4019},"  consul",[1053,4491,4040],{"class":1494},[1053,4493,4494,4496,4498],{"class":1055,"line":2362},[1053,4495,4057],{"class":4019},[1053,4497,1539],{"class":1494},[1053,4499,4500],{"class":1070}," consul:1.15\n",[1053,4502,4503,4505,4507],{"class":1055,"line":2384},[1053,4504,4231],{"class":4019},[1053,4506,1539],{"class":1494},[1053,4508,4509],{"class":1070}," consul agent -dev -client=0.0.0.0 -ui\n",[1053,4511,4512,4514],{"class":1055,"line":2423},[1053,4513,4126],{"class":4019},[1053,4515,4040],{"class":1494},[1053,4517,4518,4520,4522,4525],{"class":1055,"line":2460},[1053,4519,4111],{"class":1494},[1053,4521,4135],{"class":1861},[1053,4523,4524],{"class":1070},"8500:8500",[1053,4526,4141],{"class":1861},[1053,4528,4529,4531],{"class":1055,"line":2497},[1053,4530,4104],{"class":4019},[1053,4532,4040],{"class":1494},[1053,4534,4535,4537],{"class":1055,"line":2534},[1053,4536,4111],{"class":1494},[1053,4538,4539],{"class":1070}," consul_data:/consul/data\n",[1053,4541,4542],{"class":1055,"line":2571},[1053,4543,1110],{"emptyLinePlaceholder":1109},[1053,4545,4546],{"class":1055,"line":2585},[1053,4547,4548],{"class":1059},"  # Microservices\n",[1053,4550,4551,4554],{"class":1055,"line":2603},[1053,4552,4553],{"class":4019},"  user-service",[1053,4555,4040],{"class":1494},[1053,4557,4558,4561,4563],{"class":1055,"line":2620},[1053,4559,4560],{"class":4019},"    build",[1053,4562,1539],{"class":1494},[1053,4564,4565],{"class":1070}," ./services/user-service\n",[1053,4567,4568,4570],{"class":1055,"line":2626},[1053,4569,4067],{"class":4019},[1053,4571,4040],{"class":1494},[1053,4573,4574,4576],{"class":1055,"line":2632},[1053,4575,4111],{"class":1494},[1053,4577,4578],{"class":1070}," DEBUG=1\n",[1053,4580,4581,4583],{"class":1055,"line":2638},[1053,4582,4111],{"class":1494},[1053,4584,4585],{"class":1070}," DB_HOST=postgres\n",[1053,4587,4588,4590],{"class":1055,"line":2643},[1053,4589,4111],{"class":1494},[1053,4591,4592],{"class":1070}," DB_NAME=user_service_db\n",[1053,4594,4595,4597],{"class":1055,"line":2649},[1053,4596,4111],{"class":1494},[1053,4598,4599],{"class":1070}," DB_USER=postgres\n",[1053,4601,4602,4604],{"class":1055,"line":2659},[1053,4603,4111],{"class":1494},[1053,4605,4606],{"class":1070}," DB_PASSWORD=password\n",[1053,4608,4609,4611],{"class":1055,"line":2672},[1053,4610,4111],{"class":1494},[1053,4612,4613],{"class":1070}," REDIS_URL=redis://redis:6379/0\n",[1053,4615,4616,4618],{"class":1055,"line":2693},[1053,4617,4111],{"class":1494},[1053,4619,4620],{"class":1070}," RABBITMQ_URL=amqp://admin:password@rabbitmq:5672/\n",[1053,4622,4623,4625],{"class":1055,"line":2730},[1053,4624,4111],{"class":1494},[1053,4626,4627],{"class":1070}," CONSUL_HOST=consul\n",[1053,4629,4630,4632],{"class":1055,"line":2743},[1053,4631,4126],{"class":4019},[1053,4633,4040],{"class":1494},[1053,4635,4636,4638,4640,4643],{"class":1055,"line":2764},[1053,4637,4111],{"class":1494},[1053,4639,4135],{"class":1861},[1053,4641,4642],{"class":1070},"8001:8000",[1053,4644,4141],{"class":1861},[1053,4646,4647,4650],{"class":1055,"line":2769},[1053,4648,4649],{"class":4019},"    depends_on",[1053,4651,4040],{"class":1494},[1053,4653,4654,4657],{"class":1055,"line":2774},[1053,4655,4656],{"class":4019},"      postgres",[1053,4658,4040],{"class":1494},[1053,4660,4661,4664,4666],{"class":1055,"line":2779},[1053,4662,4663],{"class":4019},"        condition",[1053,4665,1539],{"class":1494},[1053,4667,4668],{"class":1070}," service_healthy\n",[1053,4670,4671,4674],{"class":1055,"line":2784},[1053,4672,4673],{"class":4019},"      redis",[1053,4675,4040],{"class":1494},[1053,4677,4678,4680,4682],{"class":1055,"line":2790},[1053,4679,4663],{"class":4019},[1053,4681,1539],{"class":1494},[1053,4683,4668],{"class":1070},[1053,4685,4686,4689],{"class":1055,"line":2800},[1053,4687,4688],{"class":4019},"      rabbitmq",[1053,4690,4040],{"class":1494},[1053,4692,4693,4695,4697],{"class":1055,"line":2814},[1053,4694,4663],{"class":4019},[1053,4696,1539],{"class":1494},[1053,4698,4668],{"class":1070},[1053,4700,4701,4703],{"class":1055,"line":2826},[1053,4702,4104],{"class":4019},[1053,4704,4040],{"class":1494},[1053,4706,4707,4709],{"class":1055,"line":2832},[1053,4708,4111],{"class":1494},[1053,4710,4711],{"class":1070}," ./services/user-service:/app\n",[1053,4713,4714,4716,4718],{"class":1055,"line":2846},[1053,4715,4231],{"class":4019},[1053,4717,1539],{"class":1494},[1053,4719,4720],{"class":1769}," >\n",[1053,4722,4723],{"class":1055,"line":2858},[1053,4724,4725],{"class":1070},"      sh -c \"python manage.py migrate &&\n",[1053,4727,4728],{"class":1055,"line":2863},[1053,4729,4730],{"class":1070},"             python manage.py runserver 0.0.0.0:8000\"\n",[1053,4732,4733],{"class":1055,"line":2884},[1053,4734,1110],{"emptyLinePlaceholder":1109},[1053,4736,4737,4740],{"class":1055,"line":2900},[1053,4738,4739],{"class":4019},"  product-service",[1053,4741,4040],{"class":1494},[1053,4743,4744,4746,4748],{"class":1055,"line":2914},[1053,4745,4560],{"class":4019},[1053,4747,1539],{"class":1494},[1053,4749,4750],{"class":1070}," ./services/product-service\n",[1053,4752,4753,4755],{"class":1055,"line":2926},[1053,4754,4067],{"class":4019},[1053,4756,4040],{"class":1494},[1053,4758,4759,4761],{"class":1055,"line":2936},[1053,4760,4111],{"class":1494},[1053,4762,4578],{"class":1070},[1053,4764,4765,4767],{"class":1055,"line":2941},[1053,4766,4111],{"class":1494},[1053,4768,4585],{"class":1070},[1053,4770,4771,4773],{"class":1055,"line":2955},[1053,4772,4111],{"class":1494},[1053,4774,4775],{"class":1070}," DB_NAME=product_service_db\n",[1053,4777,4778,4780],{"class":1055,"line":2976},[1053,4779,4111],{"class":1494},[1053,4781,4599],{"class":1070},[1053,4783,4784,4786],{"class":1055,"line":2995},[1053,4785,4111],{"class":1494},[1053,4787,4606],{"class":1070},[1053,4789,4790,4792],{"class":1055,"line":3000},[1053,4791,4111],{"class":1494},[1053,4793,4794],{"class":1070}," REDIS_URL=redis://redis:6379/1\n",[1053,4796,4797,4799],{"class":1055,"line":3005},[1053,4798,4111],{"class":1494},[1053,4800,4620],{"class":1070},[1053,4802,4803,4805],{"class":1055,"line":3010},[1053,4804,4111],{"class":1494},[1053,4806,4627],{"class":1070},[1053,4808,4809,4811],{"class":1055,"line":3016},[1053,4810,4126],{"class":4019},[1053,4812,4040],{"class":1494},[1053,4814,4815,4817,4819,4822],{"class":1055,"line":3055},[1053,4816,4111],{"class":1494},[1053,4818,4135],{"class":1861},[1053,4820,4821],{"class":1070},"8002:8000",[1053,4823,4141],{"class":1861},[1053,4825,4826,4828],{"class":1055,"line":3066},[1053,4827,4649],{"class":4019},[1053,4829,4040],{"class":1494},[1053,4831,4832,4834],{"class":1055,"line":3071},[1053,4833,4656],{"class":4019},[1053,4835,4040],{"class":1494},[1053,4837,4838,4840,4842],{"class":1055,"line":3077},[1053,4839,4663],{"class":4019},[1053,4841,1539],{"class":1494},[1053,4843,4668],{"class":1070},[1053,4845,4846,4848],{"class":1055,"line":3087},[1053,4847,4673],{"class":4019},[1053,4849,4040],{"class":1494},[1053,4851,4852,4854,4856],{"class":1055,"line":3104},[1053,4853,4663],{"class":4019},[1053,4855,1539],{"class":1494},[1053,4857,4668],{"class":1070},[1053,4859,4860,4862],{"class":1055,"line":3121},[1053,4861,4688],{"class":4019},[1053,4863,4040],{"class":1494},[1053,4865,4866,4868,4870],{"class":1055,"line":3135},[1053,4867,4663],{"class":4019},[1053,4869,1539],{"class":1494},[1053,4871,4668],{"class":1070},[1053,4873,4874,4876],{"class":1055,"line":3149},[1053,4875,4104],{"class":4019},[1053,4877,4040],{"class":1494},[1053,4879,4880,4882],{"class":1055,"line":3197},[1053,4881,4111],{"class":1494},[1053,4883,4884],{"class":1070}," ./services/product-service:/app\n",[1053,4886,4887],{"class":1055,"line":3218},[1053,4888,1110],{"emptyLinePlaceholder":1109},[1053,4890,4891,4894],{"class":1055,"line":3224},[1053,4892,4893],{"class":4019},"  order-service",[1053,4895,4040],{"class":1494},[1053,4897,4898,4900,4902],{"class":1055,"line":3238},[1053,4899,4560],{"class":4019},[1053,4901,1539],{"class":1494},[1053,4903,4904],{"class":1070}," ./services/order-service\n",[1053,4906,4907,4909],{"class":1055,"line":3259},[1053,4908,4067],{"class":4019},[1053,4910,4040],{"class":1494},[1053,4912,4913,4915],{"class":1055,"line":3278},[1053,4914,4111],{"class":1494},[1053,4916,4578],{"class":1070},[1053,4918,4919,4921],{"class":1055,"line":3283},[1053,4920,4111],{"class":1494},[1053,4922,4585],{"class":1070},[1053,4924,4925,4927],{"class":1055,"line":3289},[1053,4926,4111],{"class":1494},[1053,4928,4929],{"class":1070}," DB_NAME=order_service_db\n",[1053,4931,4932,4934],{"class":1055,"line":3303},[1053,4933,4111],{"class":1494},[1053,4935,4599],{"class":1070},[1053,4937,4938,4940],{"class":1055,"line":3317},[1053,4939,4111],{"class":1494},[1053,4941,4606],{"class":1070},[1053,4943,4944,4946],{"class":1055,"line":3338},[1053,4945,4111],{"class":1494},[1053,4947,4948],{"class":1070}," REDIS_URL=redis://redis:6379/2\n",[1053,4950,4951,4953],{"class":1055,"line":3359},[1053,4952,4111],{"class":1494},[1053,4954,4620],{"class":1070},[1053,4956,4957,4959],{"class":1055,"line":3380},[1053,4958,4111],{"class":1494},[1053,4960,4627],{"class":1070},[1053,4962,4963,4965],{"class":1055,"line":3400},[1053,4964,4126],{"class":4019},[1053,4966,4040],{"class":1494},[1053,4968,4969,4971,4973,4976],{"class":1055,"line":3405},[1053,4970,4111],{"class":1494},[1053,4972,4135],{"class":1861},[1053,4974,4975],{"class":1070},"8003:8000",[1053,4977,4141],{"class":1861},[1053,4979,4980,4982],{"class":1055,"line":3419},[1053,4981,4649],{"class":4019},[1053,4983,4040],{"class":1494},[1053,4985,4986,4988],{"class":1055,"line":3438},[1053,4987,4656],{"class":4019},[1053,4989,4040],{"class":1494},[1053,4991,4992,4994,4996],{"class":1055,"line":3458},[1053,4993,4663],{"class":4019},[1053,4995,1539],{"class":1494},[1053,4997,4668],{"class":1070},[1053,4999,5000,5002],{"class":1055,"line":3477},[1053,5001,4673],{"class":4019},[1053,5003,4040],{"class":1494},[1053,5005,5006,5008,5010],{"class":1055,"line":3482},[1053,5007,4663],{"class":4019},[1053,5009,1539],{"class":1494},[1053,5011,4668],{"class":1070},[1053,5013,5014,5016],{"class":1055,"line":3487},[1053,5015,4688],{"class":4019},[1053,5017,4040],{"class":1494},[1053,5019,5020,5022,5024],{"class":1055,"line":3501},[1053,5021,4663],{"class":4019},[1053,5023,1539],{"class":1494},[1053,5025,4668],{"class":1070},[1053,5027,5028,5030],{"class":1055,"line":3532},[1053,5029,4104],{"class":4019},[1053,5031,4040],{"class":1494},[1053,5033,5034,5036],{"class":1055,"line":3551},[1053,5035,4111],{"class":1494},[1053,5037,5038],{"class":1070}," ./services/order-service:/app\n",[1053,5040,5041],{"class":1055,"line":3556},[1053,5042,1110],{"emptyLinePlaceholder":1109},[1053,5044,5045],{"class":1055,"line":3561},[1053,5046,5047],{"class":1059},"  # API Gateway\n",[1053,5049,5050,5053],{"class":1055,"line":3566},[1053,5051,5052],{"class":4019},"  kong",[1053,5054,4040],{"class":1494},[1053,5056,5057,5059,5061],{"class":1055,"line":3572},[1053,5058,4057],{"class":4019},[1053,5060,1539],{"class":1494},[1053,5062,5063],{"class":1070}," kong:3.4\n",[1053,5065,5066,5068],{"class":1055,"line":3587},[1053,5067,4067],{"class":4019},[1053,5069,4040],{"class":1494},[1053,5071,5072,5075,5077,5079,5082],{"class":1055,"line":3602},[1053,5073,5074],{"class":4019},"      KONG_DATABASE",[1053,5076,1539],{"class":1494},[1053,5078,4135],{"class":1861},[1053,5080,5081],{"class":1070},"off",[1053,5083,4141],{"class":1861},[1053,5085,5086,5089,5091],{"class":1055,"line":3621},[1053,5087,5088],{"class":4019},"      KONG_DECLARATIVE_CONFIG",[1053,5090,1539],{"class":1494},[1053,5092,5093],{"class":1070}," /kong/declarative/kong.yml\n",[1053,5095,5096,5099,5101],{"class":1055,"line":3652},[1053,5097,5098],{"class":4019},"      KONG_PROXY_ACCESS_LOG",[1053,5100,1539],{"class":1494},[1053,5102,5103],{"class":1070}," /dev/stdout\n",[1053,5105,5106,5109,5111],{"class":1055,"line":3689},[1053,5107,5108],{"class":4019},"      KONG_ADMIN_ACCESS_LOG",[1053,5110,1539],{"class":1494},[1053,5112,5103],{"class":1070},[1053,5114,5116,5119,5121],{"class":1055,"line":5115},141,[1053,5117,5118],{"class":4019},"      KONG_PROXY_ERROR_LOG",[1053,5120,1539],{"class":1494},[1053,5122,5123],{"class":1070}," /dev/stderr\n",[1053,5125,5127,5130,5132],{"class":1055,"line":5126},142,[1053,5128,5129],{"class":4019},"      KONG_ADMIN_ERROR_LOG",[1053,5131,1539],{"class":1494},[1053,5133,5123],{"class":1070},[1053,5135,5137,5140,5142],{"class":1055,"line":5136},143,[1053,5138,5139],{"class":4019},"      KONG_ADMIN_LISTEN",[1053,5141,1539],{"class":1494},[1053,5143,5144],{"class":1070}," 0.0.0.0:8001\n",[1053,5146,5148,5150],{"class":1055,"line":5147},144,[1053,5149,4104],{"class":4019},[1053,5151,4040],{"class":1494},[1053,5153,5155,5157],{"class":1055,"line":5154},145,[1053,5156,4111],{"class":1494},[1053,5158,5159],{"class":1070}," ./infrastructure/docker/kong/kong.yml:/kong/declarative/kong.yml\n",[1053,5161,5163,5165],{"class":1055,"line":5162},146,[1053,5164,4126],{"class":4019},[1053,5166,4040],{"class":1494},[1053,5168,5170,5172,5174,5177],{"class":1055,"line":5169},147,[1053,5171,4111],{"class":1494},[1053,5173,4135],{"class":1861},[1053,5175,5176],{"class":1070},"8000:8000",[1053,5178,4141],{"class":1861},[1053,5180,5182,5184,5186,5189],{"class":1055,"line":5181},148,[1053,5183,4111],{"class":1494},[1053,5185,4135],{"class":1861},[1053,5187,5188],{"class":1070},"8444:8444",[1053,5190,4141],{"class":1861},[1053,5192,5194,5196],{"class":1055,"line":5193},149,[1053,5195,4649],{"class":4019},[1053,5197,4040],{"class":1494},[1053,5199,5201,5203],{"class":1055,"line":5200},150,[1053,5202,4111],{"class":1494},[1053,5204,5205],{"class":1070}," user-service\n",[1053,5207,5209,5211],{"class":1055,"line":5208},151,[1053,5210,4111],{"class":1494},[1053,5212,5213],{"class":1070}," product-service\n",[1053,5215,5217,5219],{"class":1055,"line":5216},152,[1053,5218,4111],{"class":1494},[1053,5220,5221],{"class":1070}," order-service\n",[1053,5223,5225],{"class":1055,"line":5224},153,[1053,5226,1110],{"emptyLinePlaceholder":1109},[1053,5228,5230,5233],{"class":1055,"line":5229},154,[1053,5231,5232],{"class":4019},"volumes",[1053,5234,4040],{"class":1494},[1053,5236,5238,5241],{"class":1055,"line":5237},155,[1053,5239,5240],{"class":4019},"  postgres_data",[1053,5242,4040],{"class":1494},[1053,5244,5246,5249],{"class":1055,"line":5245},156,[1053,5247,5248],{"class":4019},"  redis_data",[1053,5250,4040],{"class":1494},[1053,5252,5254,5257],{"class":1055,"line":5253},157,[1053,5255,5256],{"class":4019},"  rabbitmq_data",[1053,5258,4040],{"class":1494},[1053,5260,5262,5265],{"class":1055,"line":5261},158,[1053,5263,5264],{"class":4019},"  consul_data",[1053,5266,4040],{"class":1494},[1035,5268,5270],{"id":5269},"_3-database-initialization","3. Database Initialization",[1043,5272,5276],{"className":5273,"code":5274,"language":5275,"meta":1048,"style":1048},"language-sql shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","-- infrastructure/docker/postgres/init.sql\nCREATE DATABASE user_service_db;\nCREATE DATABASE product_service_db;\nCREATE DATABASE order_service_db;\nCREATE DATABASE payment_service_db;\n\n-- Create users for each service\nCREATE USER user_service_user WITH PASSWORD 'user_service_pass';\nCREATE USER product_service_user WITH PASSWORD 'product_service_pass';\nCREATE USER order_service_user WITH PASSWORD 'order_service_pass';\nCREATE USER payment_service_user WITH PASSWORD 'payment_service_pass';\n\n-- Grant permissions\nGRANT ALL PRIVILEGES ON DATABASE user_service_db TO user_service_user;\nGRANT ALL PRIVILEGES ON DATABASE product_service_db TO product_service_user;\nGRANT ALL PRIVILEGES ON DATABASE order_service_db TO order_service_user;\nGRANT ALL PRIVILEGES ON DATABASE payment_service_db TO payment_service_user;\n","sql",[1050,5277,5278,5283,5298,5309,5320,5331,5335,5340,5365,5387,5409,5431,5435,5440,5462,5480,5498],{"__ignoreMap":1048},[1053,5279,5280],{"class":1055,"line":1056},[1053,5281,5282],{"class":1059},"-- infrastructure/docker/postgres/init.sql\n",[1053,5284,5285,5288,5291,5295],{"class":1055,"line":1063},[1053,5286,5287],{"class":3743},"CREATE",[1053,5289,5290],{"class":3743}," DATABASE",[1053,5292,5294],{"class":5293},"sljsM"," user_service_db",[1053,5296,5297],{"class":1509},";\n",[1053,5299,5300,5302,5304,5307],{"class":1055,"line":1080},[1053,5301,5287],{"class":3743},[1053,5303,5290],{"class":3743},[1053,5305,5306],{"class":5293}," product_service_db",[1053,5308,5297],{"class":1509},[1053,5310,5311,5313,5315,5318],{"class":1055,"line":1086},[1053,5312,5287],{"class":3743},[1053,5314,5290],{"class":3743},[1053,5316,5317],{"class":5293}," order_service_db",[1053,5319,5297],{"class":1509},[1053,5321,5322,5324,5326,5329],{"class":1055,"line":1106},[1053,5323,5287],{"class":3743},[1053,5325,5290],{"class":3743},[1053,5327,5328],{"class":5293}," payment_service_db",[1053,5330,5297],{"class":1509},[1053,5332,5333],{"class":1055,"line":1113},[1053,5334,1110],{"emptyLinePlaceholder":1109},[1053,5336,5337],{"class":1055,"line":1119},[1053,5338,5339],{"class":1059},"-- Create users for each service\n",[1053,5341,5342,5344,5347,5350,5353,5356,5358,5361,5363],{"class":1055,"line":1134},[1053,5343,5287],{"class":3743},[1053,5345,5346],{"class":3743}," USER",[1053,5348,5349],{"class":5293}," user_service_user",[1053,5351,5352],{"class":3743}," WITH",[1053,5354,5355],{"class":3743}," PASSWORD",[1053,5357,2317],{"class":1861},[1053,5359,5360],{"class":1070},"user_service_pass",[1053,5362,1862],{"class":1861},[1053,5364,5297],{"class":1509},[1053,5366,5367,5369,5371,5374,5376,5378,5380,5383,5385],{"class":1055,"line":1140},[1053,5368,5287],{"class":3743},[1053,5370,5346],{"class":3743},[1053,5372,5373],{"class":5293}," product_service_user",[1053,5375,5352],{"class":3743},[1053,5377,5355],{"class":3743},[1053,5379,2317],{"class":1861},[1053,5381,5382],{"class":1070},"product_service_pass",[1053,5384,1862],{"class":1861},[1053,5386,5297],{"class":1509},[1053,5388,5389,5391,5393,5396,5398,5400,5402,5405,5407],{"class":1055,"line":1145},[1053,5390,5287],{"class":3743},[1053,5392,5346],{"class":3743},[1053,5394,5395],{"class":5293}," order_service_user",[1053,5397,5352],{"class":3743},[1053,5399,5355],{"class":3743},[1053,5401,2317],{"class":1861},[1053,5403,5404],{"class":1070},"order_service_pass",[1053,5406,1862],{"class":1861},[1053,5408,5297],{"class":1509},[1053,5410,5411,5413,5415,5418,5420,5422,5424,5427,5429],{"class":1055,"line":1151},[1053,5412,5287],{"class":3743},[1053,5414,5346],{"class":3743},[1053,5416,5417],{"class":5293}," payment_service_user",[1053,5419,5352],{"class":3743},[1053,5421,5355],{"class":3743},[1053,5423,2317],{"class":1861},[1053,5425,5426],{"class":1070},"payment_service_pass",[1053,5428,1862],{"class":1861},[1053,5430,5297],{"class":1509},[1053,5432,5433],{"class":1055,"line":1163},[1053,5434,1110],{"emptyLinePlaceholder":1109},[1053,5436,5437],{"class":1055,"line":1168},[1053,5438,5439],{"class":1059},"-- Grant permissions\n",[1053,5441,5442,5445,5448,5451,5453,5456,5459],{"class":1055,"line":1181},[1053,5443,5444],{"class":3743},"GRANT",[1053,5446,5447],{"class":1509}," ALL PRIVILEGES ",[1053,5449,5450],{"class":3743},"ON",[1053,5452,5290],{"class":3743},[1053,5454,5455],{"class":1509}," user_service_db ",[1053,5457,5458],{"class":3743},"TO",[1053,5460,5461],{"class":1509}," user_service_user;\n",[1053,5463,5464,5466,5468,5470,5472,5475,5477],{"class":1055,"line":1186},[1053,5465,5444],{"class":3743},[1053,5467,5447],{"class":1509},[1053,5469,5450],{"class":3743},[1053,5471,5290],{"class":3743},[1053,5473,5474],{"class":1509}," product_service_db ",[1053,5476,5458],{"class":3743},[1053,5478,5479],{"class":1509}," product_service_user;\n",[1053,5481,5482,5484,5486,5488,5490,5493,5495],{"class":1055,"line":1192},[1053,5483,5444],{"class":3743},[1053,5485,5447],{"class":1509},[1053,5487,5450],{"class":3743},[1053,5489,5290],{"class":3743},[1053,5491,5492],{"class":1509}," order_service_db ",[1053,5494,5458],{"class":3743},[1053,5496,5497],{"class":1509}," order_service_user;\n",[1053,5499,5500,5502,5504,5506,5508,5511,5513],{"class":1055,"line":1995},[1053,5501,5444],{"class":3743},[1053,5503,5447],{"class":1509},[1053,5505,5450],{"class":3743},[1053,5507,5290],{"class":3743},[1053,5509,5510],{"class":1509}," payment_service_db ",[1053,5512,5458],{"class":3743},[1053,5514,5515],{"class":1509}," payment_service_user;\n",[1035,5517,5519],{"id":5518},"_4-kong-api-gateway-configuration","4. Kong API Gateway Configuration",[1043,5521,5523],{"className":4005,"code":5522,"language":4007,"meta":1048,"style":1048},"# infrastructure/docker/kong/kong.yml\n_format_version: \"3.0\"\n_transform: true\n\nservices:\n  - name: user-service\n    url: http://user-service:8000\n    routes:\n      - name: user-routes\n        paths:\n          - /api/v1/users\n        strip_path: false\n    plugins:\n      - name: rate-limiting\n        config:\n          minute: 100\n          hour: 1000\n      - name: cors\n        config:\n          origins:\n            - \"*\"\n          methods:\n            - GET\n            - POST\n            - PUT\n            - DELETE\n            - OPTIONS\n          headers:\n            - Accept\n            - Accept-Version\n            - Content-Length\n            - Content-MD5\n            - Content-Type\n            - Date\n            - X-Auth-Token\n            - Authorization\n\n  - name: product-service\n    url: http://product-service:8000\n    routes:\n      - name: product-routes\n        paths:\n          - /api/v1/products\n        strip_path: false\n    plugins:\n      - name: rate-limiting\n        config:\n          minute: 200\n          hour: 2000\n\n  - name: order-service\n    url: http://order-service:8000\n    routes:\n      - name: order-routes\n        paths:\n          - /api/v1/orders\n        strip_path: false\n    plugins:\n      - name: rate-limiting\n        config:\n          minute: 150\n          hour: 1500\n",[1050,5524,5525,5530,5544,5555,5559,5565,5577,5587,5594,5605,5612,5620,5630,5637,5648,5655,5665,5675,5686,5692,5699,5711,5718,5725,5732,5739,5746,5753,5760,5767,5774,5781,5788,5795,5802,5809,5816,5820,5830,5839,5845,5856,5862,5869,5877,5883,5893,5899,5908,5917,5921,5931,5940,5946,5957,5963,5970,5978,5984,5994,6000,6009],{"__ignoreMap":1048},[1053,5526,5527],{"class":1055,"line":1056},[1053,5528,5529],{"class":1059},"# infrastructure/docker/kong/kong.yml\n",[1053,5531,5532,5535,5537,5539,5542],{"class":1055,"line":1063},[1053,5533,5534],{"class":4019},"_format_version",[1053,5536,1539],{"class":1494},[1053,5538,4135],{"class":1861},[1053,5540,5541],{"class":1070},"3.0",[1053,5543,4141],{"class":1861},[1053,5545,5546,5549,5551],{"class":1055,"line":1080},[1053,5547,5548],{"class":4019},"_transform",[1053,5550,1539],{"class":1494},[1053,5552,5554],{"class":5553},"sq3J1"," true\n",[1053,5556,5557],{"class":1055,"line":1086},[1053,5558,1110],{"emptyLinePlaceholder":1109},[1053,5560,5561,5563],{"class":1055,"line":1106},[1053,5562,4037],{"class":4019},[1053,5564,4040],{"class":1494},[1053,5566,5567,5570,5573,5575],{"class":1055,"line":1113},[1053,5568,5569],{"class":1494},"  -",[1053,5571,5572],{"class":4019}," name",[1053,5574,1539],{"class":1494},[1053,5576,5205],{"class":1070},[1053,5578,5579,5582,5584],{"class":1055,"line":1119},[1053,5580,5581],{"class":4019},"    url",[1053,5583,1539],{"class":1494},[1053,5585,5586],{"class":1070}," http://user-service:8000\n",[1053,5588,5589,5592],{"class":1055,"line":1134},[1053,5590,5591],{"class":4019},"    routes",[1053,5593,4040],{"class":1494},[1053,5595,5596,5598,5600,5602],{"class":1055,"line":1140},[1053,5597,4111],{"class":1494},[1053,5599,5572],{"class":4019},[1053,5601,1539],{"class":1494},[1053,5603,5604],{"class":1070}," user-routes\n",[1053,5606,5607,5610],{"class":1055,"line":1145},[1053,5608,5609],{"class":4019},"        paths",[1053,5611,4040],{"class":1494},[1053,5613,5614,5617],{"class":1055,"line":1151},[1053,5615,5616],{"class":1494},"          -",[1053,5618,5619],{"class":1070}," /api/v1/users\n",[1053,5621,5622,5625,5627],{"class":1055,"line":1163},[1053,5623,5624],{"class":4019},"        strip_path",[1053,5626,1539],{"class":1494},[1053,5628,5629],{"class":5553}," false\n",[1053,5631,5632,5635],{"class":1055,"line":1168},[1053,5633,5634],{"class":4019},"    plugins",[1053,5636,4040],{"class":1494},[1053,5638,5639,5641,5643,5645],{"class":1055,"line":1181},[1053,5640,4111],{"class":1494},[1053,5642,5572],{"class":4019},[1053,5644,1539],{"class":1494},[1053,5646,5647],{"class":1070}," rate-limiting\n",[1053,5649,5650,5653],{"class":1055,"line":1186},[1053,5651,5652],{"class":4019},"        config",[1053,5654,4040],{"class":1494},[1053,5656,5657,5660,5662],{"class":1055,"line":1192},[1053,5658,5659],{"class":4019},"          minute",[1053,5661,1539],{"class":1494},[1053,5663,5664],{"class":1561}," 100\n",[1053,5666,5667,5670,5672],{"class":1055,"line":1995},[1053,5668,5669],{"class":4019},"          hour",[1053,5671,1539],{"class":1494},[1053,5673,5674],{"class":1561}," 1000\n",[1053,5676,5677,5679,5681,5683],{"class":1055,"line":2007},[1053,5678,4111],{"class":1494},[1053,5680,5572],{"class":4019},[1053,5682,1539],{"class":1494},[1053,5684,5685],{"class":1070}," cors\n",[1053,5687,5688,5690],{"class":1055,"line":2019},[1053,5689,5652],{"class":4019},[1053,5691,4040],{"class":1494},[1053,5693,5694,5697],{"class":1055,"line":2031},[1053,5695,5696],{"class":4019},"          origins",[1053,5698,4040],{"class":1494},[1053,5700,5701,5704,5706,5709],{"class":1055,"line":2043},[1053,5702,5703],{"class":1494},"            -",[1053,5705,4135],{"class":1861},[1053,5707,5708],{"class":1070},"*",[1053,5710,4141],{"class":1861},[1053,5712,5713,5716],{"class":1055,"line":2049},[1053,5714,5715],{"class":4019},"          methods",[1053,5717,4040],{"class":1494},[1053,5719,5720,5722],{"class":1055,"line":2054},[1053,5721,5703],{"class":1494},[1053,5723,5724],{"class":1070}," GET\n",[1053,5726,5727,5729],{"class":1055,"line":2064},[1053,5728,5703],{"class":1494},[1053,5730,5731],{"class":1070}," POST\n",[1053,5733,5734,5736],{"class":1055,"line":2076},[1053,5735,5703],{"class":1494},[1053,5737,5738],{"class":1070}," PUT\n",[1053,5740,5741,5743],{"class":1055,"line":2088},[1053,5742,5703],{"class":1494},[1053,5744,5745],{"class":1070}," DELETE\n",[1053,5747,5748,5750],{"class":1055,"line":2100},[1053,5749,5703],{"class":1494},[1053,5751,5752],{"class":1070}," OPTIONS\n",[1053,5754,5755,5758],{"class":1055,"line":2105},[1053,5756,5757],{"class":4019},"          headers",[1053,5759,4040],{"class":1494},[1053,5761,5762,5764],{"class":1055,"line":2110},[1053,5763,5703],{"class":1494},[1053,5765,5766],{"class":1070}," Accept\n",[1053,5768,5769,5771],{"class":1055,"line":2120},[1053,5770,5703],{"class":1494},[1053,5772,5773],{"class":1070}," Accept-Version\n",[1053,5775,5776,5778],{"class":1055,"line":2132},[1053,5777,5703],{"class":1494},[1053,5779,5780],{"class":1070}," Content-Length\n",[1053,5782,5783,5785],{"class":1055,"line":2137},[1053,5784,5703],{"class":1494},[1053,5786,5787],{"class":1070}," Content-MD5\n",[1053,5789,5790,5792],{"class":1055,"line":2142},[1053,5791,5703],{"class":1494},[1053,5793,5794],{"class":1070}," Content-Type\n",[1053,5796,5797,5799],{"class":1055,"line":2164},[1053,5798,5703],{"class":1494},[1053,5800,5801],{"class":1070}," Date\n",[1053,5803,5804,5806],{"class":1055,"line":2169},[1053,5805,5703],{"class":1494},[1053,5807,5808],{"class":1070}," X-Auth-Token\n",[1053,5810,5811,5813],{"class":1055,"line":2179},[1053,5812,5703],{"class":1494},[1053,5814,5815],{"class":1070}," Authorization\n",[1053,5817,5818],{"class":1055,"line":2191},[1053,5819,1110],{"emptyLinePlaceholder":1109},[1053,5821,5822,5824,5826,5828],{"class":1055,"line":2203},[1053,5823,5569],{"class":1494},[1053,5825,5572],{"class":4019},[1053,5827,1539],{"class":1494},[1053,5829,5213],{"class":1070},[1053,5831,5832,5834,5836],{"class":1055,"line":2215},[1053,5833,5581],{"class":4019},[1053,5835,1539],{"class":1494},[1053,5837,5838],{"class":1070}," http://product-service:8000\n",[1053,5840,5841,5843],{"class":1055,"line":2227},[1053,5842,5591],{"class":4019},[1053,5844,4040],{"class":1494},[1053,5846,5847,5849,5851,5853],{"class":1055,"line":2239},[1053,5848,4111],{"class":1494},[1053,5850,5572],{"class":4019},[1053,5852,1539],{"class":1494},[1053,5854,5855],{"class":1070}," product-routes\n",[1053,5857,5858,5860],{"class":1055,"line":2251},[1053,5859,5609],{"class":4019},[1053,5861,4040],{"class":1494},[1053,5863,5864,5866],{"class":1055,"line":2263},[1053,5865,5616],{"class":1494},[1053,5867,5868],{"class":1070}," /api/v1/products\n",[1053,5870,5871,5873,5875],{"class":1055,"line":2275},[1053,5872,5624],{"class":4019},[1053,5874,1539],{"class":1494},[1053,5876,5629],{"class":5553},[1053,5878,5879,5881],{"class":1055,"line":2287},[1053,5880,5634],{"class":4019},[1053,5882,4040],{"class":1494},[1053,5884,5885,5887,5889,5891],{"class":1055,"line":2299},[1053,5886,4111],{"class":1494},[1053,5888,5572],{"class":4019},[1053,5890,1539],{"class":1494},[1053,5892,5647],{"class":1070},[1053,5894,5895,5897],{"class":1055,"line":2304},[1053,5896,5652],{"class":4019},[1053,5898,4040],{"class":1494},[1053,5900,5901,5903,5905],{"class":1055,"line":2309},[1053,5902,5659],{"class":4019},[1053,5904,1539],{"class":1494},[1053,5906,5907],{"class":1561}," 200\n",[1053,5909,5910,5912,5914],{"class":1055,"line":2326},[1053,5911,5669],{"class":4019},[1053,5913,1539],{"class":1494},[1053,5915,5916],{"class":1561}," 2000\n",[1053,5918,5919],{"class":1055,"line":2331},[1053,5920,1110],{"emptyLinePlaceholder":1109},[1053,5922,5923,5925,5927,5929],{"class":1055,"line":2337},[1053,5924,5569],{"class":1494},[1053,5926,5572],{"class":4019},[1053,5928,1539],{"class":1494},[1053,5930,5221],{"class":1070},[1053,5932,5933,5935,5937],{"class":1055,"line":2348},[1053,5934,5581],{"class":4019},[1053,5936,1539],{"class":1494},[1053,5938,5939],{"class":1070}," http://order-service:8000\n",[1053,5941,5942,5944],{"class":1055,"line":2362},[1053,5943,5591],{"class":4019},[1053,5945,4040],{"class":1494},[1053,5947,5948,5950,5952,5954],{"class":1055,"line":2384},[1053,5949,4111],{"class":1494},[1053,5951,5572],{"class":4019},[1053,5953,1539],{"class":1494},[1053,5955,5956],{"class":1070}," order-routes\n",[1053,5958,5959,5961],{"class":1055,"line":2423},[1053,5960,5609],{"class":4019},[1053,5962,4040],{"class":1494},[1053,5964,5965,5967],{"class":1055,"line":2460},[1053,5966,5616],{"class":1494},[1053,5968,5969],{"class":1070}," /api/v1/orders\n",[1053,5971,5972,5974,5976],{"class":1055,"line":2497},[1053,5973,5624],{"class":4019},[1053,5975,1539],{"class":1494},[1053,5977,5629],{"class":5553},[1053,5979,5980,5982],{"class":1055,"line":2534},[1053,5981,5634],{"class":4019},[1053,5983,4040],{"class":1494},[1053,5985,5986,5988,5990,5992],{"class":1055,"line":2571},[1053,5987,4111],{"class":1494},[1053,5989,5572],{"class":4019},[1053,5991,1539],{"class":1494},[1053,5993,5647],{"class":1070},[1053,5995,5996,5998],{"class":1055,"line":2585},[1053,5997,5652],{"class":4019},[1053,5999,4040],{"class":1494},[1053,6001,6002,6004,6006],{"class":1055,"line":2603},[1053,6003,5659],{"class":4019},[1053,6005,1539],{"class":1494},[1053,6007,6008],{"class":1561}," 150\n",[1053,6010,6011,6013,6015],{"class":1055,"line":2620},[1053,6012,5669],{"class":4019},[1053,6014,1539],{"class":1494},[1053,6016,6017],{"class":1561}," 1500\n",[1030,6019,6021],{"id":6020},"development-scripts","Development Scripts",[1035,6023,6025],{"id":6024},"_1-setup-script","1. Setup Script",[1043,6027,6029],{"className":1045,"code":6028,"language":1047,"meta":1048,"style":1048},"#!/bin/bash\n# scripts/setup-dev.sh\n\nset -e\n\necho \"Setting up Django Microservices Development Environment...\"\n\n# Create virtual environments for each service\nservices=(\"user-service\" \"product-service\" \"order-service\" \"payment-service\")\n\nfor service in \"${services[@]}\"; do\n    echo \"Setting up $service...\"\n    \n    cd \"services/$service\"\n    \n    # Create virtual environment\n    python3.11 -m venv venv\n    source venv/bin/activate\n    \n    # Install dependencies\n    pip install --upgrade pip\n    if [ -f \"requirements.txt\" ]; then\n        pip install -r requirements.txt\n    fi\n    \n    # Run migrations\n    if [ -f \"manage.py\" ]; then\n        python manage.py migrate\n    fi\n    \n    deactivate\n    cd ../..\ndone\n\necho \"Development environment setup complete!\"\necho \"Run 'docker-compose up' to start all services\"\n",[1050,6030,6031,6036,6041,6045,6053,6057,6069,6073,6078,6115,6119,6154,6172,6177,6191,6195,6200,6211,6218,6222,6227,6238,6261,6273,6278,6282,6287,6306,6316,6320,6324,6329,6336,6341,6345,6356],{"__ignoreMap":1048},[1053,6032,6033],{"class":1055,"line":1056},[1053,6034,6035],{"class":1059},"#!/bin/bash\n",[1053,6037,6038],{"class":1055,"line":1063},[1053,6039,6040],{"class":1059},"# scripts/setup-dev.sh\n",[1053,6042,6043],{"class":1055,"line":1080},[1053,6044,1110],{"emptyLinePlaceholder":1109},[1053,6046,6047,6050],{"class":1055,"line":1086},[1053,6048,6049],{"class":1235},"set",[1053,6051,6052],{"class":1254}," -e\n",[1053,6054,6055],{"class":1055,"line":1106},[1053,6056,1110],{"emptyLinePlaceholder":1109},[1053,6058,6059,6062,6064,6067],{"class":1055,"line":1113},[1053,6060,6061],{"class":1235},"echo",[1053,6063,4135],{"class":1861},[1053,6065,6066],{"class":1070},"Setting up Django Microservices Development Environment...",[1053,6068,4141],{"class":1861},[1053,6070,6071],{"class":1055,"line":1119},[1053,6072,1110],{"emptyLinePlaceholder":1109},[1053,6074,6075],{"class":1055,"line":1134},[1053,6076,6077],{"class":1059},"# Create virtual environments for each service\n",[1053,6079,6080,6083,6086,6088,6090,6092,6094,6097,6099,6101,6104,6106,6108,6111,6113],{"class":1055,"line":1140},[1053,6081,4037],{"class":6082},"sSC40",[1053,6084,6085],{"class":1494},"=(",[1053,6087,4160],{"class":1861},[1053,6089,3582],{"class":1070},[1053,6091,4160],{"class":1861},[1053,6093,4135],{"class":1861},[1053,6095,6096],{"class":1070},"product-service",[1053,6098,4160],{"class":1861},[1053,6100,4135],{"class":1861},[1053,6102,6103],{"class":1070},"order-service",[1053,6105,4160],{"class":1861},[1053,6107,4135],{"class":1861},[1053,6109,6110],{"class":1070},"payment-service",[1053,6112,4160],{"class":1861},[1053,6114,1869],{"class":1494},[1053,6116,6117],{"class":1055,"line":1145},[1053,6118,1110],{"emptyLinePlaceholder":1109},[1053,6120,6121,6124,6127,6130,6132,6135,6138,6141,6143,6146,6148,6151],{"class":1055,"line":1151},[1053,6122,6123],{"class":1769},"for",[1053,6125,6126],{"class":6082}," service",[1053,6128,6129],{"class":1769}," in",[1053,6131,4135],{"class":1861},[1053,6133,6134],{"class":1494},"${",[1053,6136,4037],{"class":6137},"su_V2",[1053,6139,6140],{"class":1494},"[",[1053,6142,1553],{"class":1422},[1053,6144,6145],{"class":1494},"]}",[1053,6147,4160],{"class":1861},[1053,6149,6150],{"class":1494},";",[1053,6152,6153],{"class":1769}," do\n",[1053,6155,6156,6159,6161,6164,6167,6170],{"class":1055,"line":1163},[1053,6157,6158],{"class":1235},"    echo",[1053,6160,4135],{"class":1861},[1053,6162,6163],{"class":1070},"Setting up ",[1053,6165,6166],{"class":6137},"$service",[1053,6168,6169],{"class":1070},"...",[1053,6171,4141],{"class":1861},[1053,6173,6174],{"class":1055,"line":1168},[1053,6175,6176],{"class":1509},"    \n",[1053,6178,6179,6182,6184,6187,6189],{"class":1055,"line":1181},[1053,6180,6181],{"class":1235},"    cd",[1053,6183,4135],{"class":1861},[1053,6185,6186],{"class":1070},"services/",[1053,6188,6166],{"class":6137},[1053,6190,4141],{"class":1861},[1053,6192,6193],{"class":1055,"line":1186},[1053,6194,6176],{"class":1509},[1053,6196,6197],{"class":1055,"line":1192},[1053,6198,6199],{"class":1059},"    # Create virtual environment\n",[1053,6201,6202,6205,6207,6209],{"class":1055,"line":1995},[1053,6203,6204],{"class":1066},"    python3.11",[1053,6206,1361],{"class":1254},[1053,6208,1364],{"class":1070},[1053,6210,1367],{"class":1070},[1053,6212,6213,6216],{"class":1055,"line":2007},[1053,6214,6215],{"class":1235},"    source",[1053,6217,1375],{"class":1070},[1053,6219,6220],{"class":1055,"line":2019},[1053,6221,6176],{"class":1509},[1053,6223,6224],{"class":1055,"line":2031},[1053,6225,6226],{"class":1059},"    # Install dependencies\n",[1053,6228,6229,6232,6234,6236],{"class":1055,"line":2043},[1053,6230,6231],{"class":1066},"    pip",[1053,6233,1071],{"class":1070},[1053,6235,1394],{"class":1254},[1053,6237,1397],{"class":1070},[1053,6239,6240,6243,6245,6248,6250,6253,6255,6258],{"class":1055,"line":2049},[1053,6241,6242],{"class":1769},"    if",[1053,6244,3512],{"class":1494},[1053,6246,6247],{"class":1422}," -f",[1053,6249,4135],{"class":1861},[1053,6251,6252],{"class":1070},"requirements.txt",[1053,6254,4160],{"class":1861},[1053,6256,6257],{"class":1494}," ];",[1053,6259,6260],{"class":1769}," then\n",[1053,6262,6263,6266,6268,6271],{"class":1055,"line":2054},[1053,6264,6265],{"class":1066},"        pip",[1053,6267,1071],{"class":1070},[1053,6269,6270],{"class":1254}," -r",[1053,6272,1426],{"class":1070},[1053,6274,6275],{"class":1055,"line":2064},[1053,6276,6277],{"class":1769},"    fi\n",[1053,6279,6280],{"class":1055,"line":2076},[1053,6281,6176],{"class":1509},[1053,6283,6284],{"class":1055,"line":2088},[1053,6285,6286],{"class":1059},"    # Run migrations\n",[1053,6288,6289,6291,6293,6295,6297,6300,6302,6304],{"class":1055,"line":2100},[1053,6290,6242],{"class":1769},[1053,6292,3512],{"class":1494},[1053,6294,6247],{"class":1422},[1053,6296,4135],{"class":1861},[1053,6298,6299],{"class":1070},"manage.py",[1053,6301,4160],{"class":1861},[1053,6303,6257],{"class":1494},[1053,6305,6260],{"class":1769},[1053,6307,6308,6311,6313],{"class":1055,"line":2105},[1053,6309,6310],{"class":1066},"        python",[1053,6312,1464],{"class":1070},[1053,6314,6315],{"class":1070}," migrate\n",[1053,6317,6318],{"class":1055,"line":2110},[1053,6319,6277],{"class":1769},[1053,6321,6322],{"class":1055,"line":2120},[1053,6323,6176],{"class":1509},[1053,6325,6326],{"class":1055,"line":2132},[1053,6327,6328],{"class":1066},"    deactivate\n",[1053,6330,6331,6333],{"class":1055,"line":2137},[1053,6332,6181],{"class":1235},[1053,6334,6335],{"class":1070}," ../..\n",[1053,6337,6338],{"class":1055,"line":2142},[1053,6339,6340],{"class":1769},"done\n",[1053,6342,6343],{"class":1055,"line":2164},[1053,6344,1110],{"emptyLinePlaceholder":1109},[1053,6346,6347,6349,6351,6354],{"class":1055,"line":2169},[1053,6348,6061],{"class":1235},[1053,6350,4135],{"class":1861},[1053,6352,6353],{"class":1070},"Development environment setup complete!",[1053,6355,4141],{"class":1861},[1053,6357,6358,6360,6362,6365],{"class":1055,"line":2179},[1053,6359,6061],{"class":1235},[1053,6361,4135],{"class":1861},[1053,6363,6364],{"class":1070},"Run 'docker-compose up' to start all services",[1053,6366,4141],{"class":1861},[1035,6368,6370],{"id":6369},"_2-service-management-script","2. Service Management Script",[1043,6372,6374],{"className":1045,"code":6373,"language":1047,"meta":1048,"style":1048},"#!/bin/bash\n# scripts/manage-services.sh\n\nCOMMAND=$1\nSERVICE=$2\n\ncase $COMMAND in\n    \"start\")\n        if [ -z \"$SERVICE\" ]; then\n            echo \"Starting all services...\"\n            docker-compose up -d\n        else\n            echo \"Starting $SERVICE...\"\n            docker-compose up -d $SERVICE\n        fi\n        ;;\n    \"stop\")\n        if [ -z \"$SERVICE\" ]; then\n            echo \"Stopping all services...\"\n            docker-compose down\n        else\n            echo \"Stopping $SERVICE...\"\n            docker-compose stop $SERVICE\n        fi\n        ;;\n    \"restart\")\n        if [ -z \"$SERVICE\" ]; then\n            echo \"Restarting all services...\"\n            docker-compose restart\n        else\n            echo \"Restarting $SERVICE...\"\n            docker-compose restart $SERVICE\n        fi\n        ;;\n    \"logs\")\n        if [ -z \"$SERVICE\" ]; then\n            docker-compose logs -f\n        else\n            docker-compose logs -f $SERVICE\n        fi\n        ;;\n    \"shell\")\n        if [ -z \"$SERVICE\" ]; then\n            echo \"Please specify a service name\"\n            exit 1\n        fi\n        docker-compose exec $SERVICE /bin/bash\n        ;;\n    \"migrate\")\n        if [ -z \"$SERVICE\" ]; then\n            echo \"Please specify a service name\"\n            exit 1\n        fi\n        docker-compose exec $SERVICE python manage.py migrate\n        ;;\n    *)\n        echo \"Usage: $0 {start|stop|restart|logs|shell|migrate} [service-name]\"\n        exit 1\n        ;;\nesac\n",[1050,6375,6376,6380,6385,6389,6399,6409,6413,6424,6436,6457,6469,6480,6485,6500,6512,6517,6522,6533,6551,6562,6569,6573,6588,6597,6601,6605,6616,6634,6645,6652,6656,6671,6680,6684,6688,6699,6717,6727,6731,6741,6745,6749,6760,6778,6789,6797,6801,6815,6819,6830,6848,6858,6864,6868,6883,6887,6892,6911,6918,6922],{"__ignoreMap":1048},[1053,6377,6378],{"class":1055,"line":1056},[1053,6379,6035],{"class":1059},[1053,6381,6382],{"class":1055,"line":1063},[1053,6383,6384],{"class":1059},"# scripts/manage-services.sh\n",[1053,6386,6387],{"class":1055,"line":1080},[1053,6388,1110],{"emptyLinePlaceholder":1109},[1053,6390,6391,6394,6396],{"class":1055,"line":1086},[1053,6392,6393],{"class":6082},"COMMAND",[1053,6395,1495],{"class":1494},[1053,6397,6398],{"class":1890},"$1\n",[1053,6400,6401,6404,6406],{"class":1055,"line":1106},[1053,6402,6403],{"class":6082},"SERVICE",[1053,6405,1495],{"class":1494},[1053,6407,6408],{"class":1890},"$2\n",[1053,6410,6411],{"class":1055,"line":1113},[1053,6412,1110],{"emptyLinePlaceholder":1109},[1053,6414,6415,6418,6421],{"class":1055,"line":1119},[1053,6416,6417],{"class":1769},"case",[1053,6419,6420],{"class":6082}," $COMMAND",[1053,6422,6423],{"class":1769}," in\n",[1053,6425,6426,6429,6432,6434],{"class":1055,"line":1134},[1053,6427,6428],{"class":1861},"    \"",[1053,6430,6431],{"class":1070},"start",[1053,6433,4160],{"class":1861},[1053,6435,1869],{"class":1422},[1053,6437,6438,6441,6443,6446,6448,6451,6453,6455],{"class":1055,"line":1140},[1053,6439,6440],{"class":1769},"        if",[1053,6442,3512],{"class":1494},[1053,6444,6445],{"class":1422}," -z",[1053,6447,4135],{"class":1861},[1053,6449,6450],{"class":6137},"$SERVICE",[1053,6452,4160],{"class":1861},[1053,6454,6257],{"class":1494},[1053,6456,6260],{"class":1769},[1053,6458,6459,6462,6464,6467],{"class":1055,"line":1145},[1053,6460,6461],{"class":1235},"            echo",[1053,6463,4135],{"class":1861},[1053,6465,6466],{"class":1070},"Starting all services...",[1053,6468,4141],{"class":1861},[1053,6470,6471,6474,6477],{"class":1055,"line":1151},[1053,6472,6473],{"class":1066},"            docker-compose",[1053,6475,6476],{"class":1070}," up",[1053,6478,6479],{"class":1254}," -d\n",[1053,6481,6482],{"class":1055,"line":1163},[1053,6483,6484],{"class":1769},"        else\n",[1053,6486,6487,6489,6491,6494,6496,6498],{"class":1055,"line":1168},[1053,6488,6461],{"class":1235},[1053,6490,4135],{"class":1861},[1053,6492,6493],{"class":1070},"Starting ",[1053,6495,6450],{"class":6137},[1053,6497,6169],{"class":1070},[1053,6499,4141],{"class":1861},[1053,6501,6502,6504,6506,6509],{"class":1055,"line":1181},[1053,6503,6473],{"class":1066},[1053,6505,6476],{"class":1070},[1053,6507,6508],{"class":1254}," -d",[1053,6510,6511],{"class":6082}," $SERVICE\n",[1053,6513,6514],{"class":1055,"line":1186},[1053,6515,6516],{"class":1769},"        fi\n",[1053,6518,6519],{"class":1055,"line":1192},[1053,6520,6521],{"class":1494},"        ;;\n",[1053,6523,6524,6526,6529,6531],{"class":1055,"line":1995},[1053,6525,6428],{"class":1861},[1053,6527,6528],{"class":1070},"stop",[1053,6530,4160],{"class":1861},[1053,6532,1869],{"class":1422},[1053,6534,6535,6537,6539,6541,6543,6545,6547,6549],{"class":1055,"line":2007},[1053,6536,6440],{"class":1769},[1053,6538,3512],{"class":1494},[1053,6540,6445],{"class":1422},[1053,6542,4135],{"class":1861},[1053,6544,6450],{"class":6137},[1053,6546,4160],{"class":1861},[1053,6548,6257],{"class":1494},[1053,6550,6260],{"class":1769},[1053,6552,6553,6555,6557,6560],{"class":1055,"line":2019},[1053,6554,6461],{"class":1235},[1053,6556,4135],{"class":1861},[1053,6558,6559],{"class":1070},"Stopping all services...",[1053,6561,4141],{"class":1861},[1053,6563,6564,6566],{"class":1055,"line":2031},[1053,6565,6473],{"class":1066},[1053,6567,6568],{"class":1070}," down\n",[1053,6570,6571],{"class":1055,"line":2043},[1053,6572,6484],{"class":1769},[1053,6574,6575,6577,6579,6582,6584,6586],{"class":1055,"line":2049},[1053,6576,6461],{"class":1235},[1053,6578,4135],{"class":1861},[1053,6580,6581],{"class":1070},"Stopping ",[1053,6583,6450],{"class":6137},[1053,6585,6169],{"class":1070},[1053,6587,4141],{"class":1861},[1053,6589,6590,6592,6595],{"class":1055,"line":2054},[1053,6591,6473],{"class":1066},[1053,6593,6594],{"class":1070}," stop",[1053,6596,6511],{"class":6082},[1053,6598,6599],{"class":1055,"line":2064},[1053,6600,6516],{"class":1769},[1053,6602,6603],{"class":1055,"line":2076},[1053,6604,6521],{"class":1494},[1053,6606,6607,6609,6612,6614],{"class":1055,"line":2088},[1053,6608,6428],{"class":1861},[1053,6610,6611],{"class":1070},"restart",[1053,6613,4160],{"class":1861},[1053,6615,1869],{"class":1422},[1053,6617,6618,6620,6622,6624,6626,6628,6630,6632],{"class":1055,"line":2100},[1053,6619,6440],{"class":1769},[1053,6621,3512],{"class":1494},[1053,6623,6445],{"class":1422},[1053,6625,4135],{"class":1861},[1053,6627,6450],{"class":6137},[1053,6629,4160],{"class":1861},[1053,6631,6257],{"class":1494},[1053,6633,6260],{"class":1769},[1053,6635,6636,6638,6640,6643],{"class":1055,"line":2105},[1053,6637,6461],{"class":1235},[1053,6639,4135],{"class":1861},[1053,6641,6642],{"class":1070},"Restarting all services...",[1053,6644,4141],{"class":1861},[1053,6646,6647,6649],{"class":1055,"line":2110},[1053,6648,6473],{"class":1066},[1053,6650,6651],{"class":1070}," restart\n",[1053,6653,6654],{"class":1055,"line":2120},[1053,6655,6484],{"class":1769},[1053,6657,6658,6660,6662,6665,6667,6669],{"class":1055,"line":2132},[1053,6659,6461],{"class":1235},[1053,6661,4135],{"class":1861},[1053,6663,6664],{"class":1070},"Restarting ",[1053,6666,6450],{"class":6137},[1053,6668,6169],{"class":1070},[1053,6670,4141],{"class":1861},[1053,6672,6673,6675,6678],{"class":1055,"line":2137},[1053,6674,6473],{"class":1066},[1053,6676,6677],{"class":1070}," restart",[1053,6679,6511],{"class":6082},[1053,6681,6682],{"class":1055,"line":2142},[1053,6683,6516],{"class":1769},[1053,6685,6686],{"class":1055,"line":2164},[1053,6687,6521],{"class":1494},[1053,6689,6690,6692,6695,6697],{"class":1055,"line":2169},[1053,6691,6428],{"class":1861},[1053,6693,6694],{"class":1070},"logs",[1053,6696,4160],{"class":1861},[1053,6698,1869],{"class":1422},[1053,6700,6701,6703,6705,6707,6709,6711,6713,6715],{"class":1055,"line":2179},[1053,6702,6440],{"class":1769},[1053,6704,3512],{"class":1494},[1053,6706,6445],{"class":1422},[1053,6708,4135],{"class":1861},[1053,6710,6450],{"class":6137},[1053,6712,4160],{"class":1861},[1053,6714,6257],{"class":1494},[1053,6716,6260],{"class":1769},[1053,6718,6719,6721,6724],{"class":1055,"line":2191},[1053,6720,6473],{"class":1066},[1053,6722,6723],{"class":1070}," logs",[1053,6725,6726],{"class":1254}," -f\n",[1053,6728,6729],{"class":1055,"line":2203},[1053,6730,6484],{"class":1769},[1053,6732,6733,6735,6737,6739],{"class":1055,"line":2215},[1053,6734,6473],{"class":1066},[1053,6736,6723],{"class":1070},[1053,6738,6247],{"class":1254},[1053,6740,6511],{"class":6082},[1053,6742,6743],{"class":1055,"line":2227},[1053,6744,6516],{"class":1769},[1053,6746,6747],{"class":1055,"line":2239},[1053,6748,6521],{"class":1494},[1053,6750,6751,6753,6756,6758],{"class":1055,"line":2251},[1053,6752,6428],{"class":1861},[1053,6754,6755],{"class":1070},"shell",[1053,6757,4160],{"class":1861},[1053,6759,1869],{"class":1422},[1053,6761,6762,6764,6766,6768,6770,6772,6774,6776],{"class":1055,"line":2263},[1053,6763,6440],{"class":1769},[1053,6765,3512],{"class":1494},[1053,6767,6445],{"class":1422},[1053,6769,4135],{"class":1861},[1053,6771,6450],{"class":6137},[1053,6773,4160],{"class":1861},[1053,6775,6257],{"class":1494},[1053,6777,6260],{"class":1769},[1053,6779,6780,6782,6784,6787],{"class":1055,"line":2275},[1053,6781,6461],{"class":1235},[1053,6783,4135],{"class":1861},[1053,6785,6786],{"class":1070},"Please specify a service name",[1053,6788,4141],{"class":1861},[1053,6790,6791,6794],{"class":1055,"line":2287},[1053,6792,6793],{"class":1235},"            exit",[1053,6795,6796],{"class":1561}," 1\n",[1053,6798,6799],{"class":1055,"line":2299},[1053,6800,6516],{"class":1769},[1053,6802,6803,6806,6809,6812],{"class":1055,"line":2304},[1053,6804,6805],{"class":1066},"        docker-compose",[1053,6807,6808],{"class":1070}," exec",[1053,6810,6811],{"class":6082}," $SERVICE",[1053,6813,6814],{"class":1070}," /bin/bash\n",[1053,6816,6817],{"class":1055,"line":2309},[1053,6818,6521],{"class":1494},[1053,6820,6821,6823,6826,6828],{"class":1055,"line":2326},[1053,6822,6428],{"class":1861},[1053,6824,6825],{"class":1070},"migrate",[1053,6827,4160],{"class":1861},[1053,6829,1869],{"class":1422},[1053,6831,6832,6834,6836,6838,6840,6842,6844,6846],{"class":1055,"line":2331},[1053,6833,6440],{"class":1769},[1053,6835,3512],{"class":1494},[1053,6837,6445],{"class":1422},[1053,6839,4135],{"class":1861},[1053,6841,6450],{"class":6137},[1053,6843,4160],{"class":1861},[1053,6845,6257],{"class":1494},[1053,6847,6260],{"class":1769},[1053,6849,6850,6852,6854,6856],{"class":1055,"line":2337},[1053,6851,6461],{"class":1235},[1053,6853,4135],{"class":1861},[1053,6855,6786],{"class":1070},[1053,6857,4141],{"class":1861},[1053,6859,6860,6862],{"class":1055,"line":2348},[1053,6861,6793],{"class":1235},[1053,6863,6796],{"class":1561},[1053,6865,6866],{"class":1055,"line":2362},[1053,6867,6516],{"class":1769},[1053,6869,6870,6872,6874,6876,6879,6881],{"class":1055,"line":2384},[1053,6871,6805],{"class":1066},[1053,6873,6808],{"class":1070},[1053,6875,6811],{"class":6082},[1053,6877,6878],{"class":1070}," python",[1053,6880,1464],{"class":1070},[1053,6882,6315],{"class":1070},[1053,6884,6885],{"class":1055,"line":2423},[1053,6886,6521],{"class":1494},[1053,6888,6889],{"class":1055,"line":2460},[1053,6890,6891],{"class":1422},"    *)\n",[1053,6893,6894,6897,6899,6902,6906,6909],{"class":1055,"line":2497},[1053,6895,6896],{"class":1235},"        echo",[1053,6898,4135],{"class":1861},[1053,6900,6901],{"class":1070},"Usage: ",[1053,6903,6905],{"class":6904},"sVyVU","$0",[1053,6907,6908],{"class":1070}," {start|stop|restart|logs|shell|migrate} [service-name]",[1053,6910,4141],{"class":1861},[1053,6912,6913,6916],{"class":1055,"line":2534},[1053,6914,6915],{"class":1235},"        exit",[1053,6917,6796],{"class":1561},[1053,6919,6920],{"class":1055,"line":2571},[1053,6921,6521],{"class":1494},[1053,6923,6924],{"class":1055,"line":2585},[1053,6925,6926],{"class":1769},"esac\n",[1035,6928,6930],{"id":6929},"_3-testing-script","3. Testing Script",[1043,6932,6934],{"className":1045,"code":6933,"language":1047,"meta":1048,"style":1048},"#!/bin/bash\n# scripts/run-tests.sh\n\nset -e\n\necho \"Running tests for all microservices...\"\n\nservices=(\"user-service\" \"product-service\" \"order-service\" \"payment-service\")\n\nfor service in \"${services[@]}\"; do\n    echo \"Testing $service...\"\n    \n    if [ -d \"services/$service\" ]; then\n        cd \"services/$service\"\n        \n        # Activate virtual environment\n        source venv/bin/activate\n        \n        # Run tests\n        if [ -f \"manage.py\" ]; then\n            python manage.py test\n        fi\n        \n        deactivate\n        cd ../..\n    fi\ndone\n\necho \"All tests completed!\"\n",[1050,6935,6936,6940,6945,6949,6955,6959,6970,6974,7006,7010,7036,7051,7055,7075,7088,7093,7098,7105,7109,7114,7132,7142,7146,7150,7155,7161,7165,7169,7173],{"__ignoreMap":1048},[1053,6937,6938],{"class":1055,"line":1056},[1053,6939,6035],{"class":1059},[1053,6941,6942],{"class":1055,"line":1063},[1053,6943,6944],{"class":1059},"# scripts/run-tests.sh\n",[1053,6946,6947],{"class":1055,"line":1080},[1053,6948,1110],{"emptyLinePlaceholder":1109},[1053,6950,6951,6953],{"class":1055,"line":1086},[1053,6952,6049],{"class":1235},[1053,6954,6052],{"class":1254},[1053,6956,6957],{"class":1055,"line":1106},[1053,6958,1110],{"emptyLinePlaceholder":1109},[1053,6960,6961,6963,6965,6968],{"class":1055,"line":1113},[1053,6962,6061],{"class":1235},[1053,6964,4135],{"class":1861},[1053,6966,6967],{"class":1070},"Running tests for all microservices...",[1053,6969,4141],{"class":1861},[1053,6971,6972],{"class":1055,"line":1119},[1053,6973,1110],{"emptyLinePlaceholder":1109},[1053,6975,6976,6978,6980,6982,6984,6986,6988,6990,6992,6994,6996,6998,7000,7002,7004],{"class":1055,"line":1134},[1053,6977,4037],{"class":6082},[1053,6979,6085],{"class":1494},[1053,6981,4160],{"class":1861},[1053,6983,3582],{"class":1070},[1053,6985,4160],{"class":1861},[1053,6987,4135],{"class":1861},[1053,6989,6096],{"class":1070},[1053,6991,4160],{"class":1861},[1053,6993,4135],{"class":1861},[1053,6995,6103],{"class":1070},[1053,6997,4160],{"class":1861},[1053,6999,4135],{"class":1861},[1053,7001,6110],{"class":1070},[1053,7003,4160],{"class":1861},[1053,7005,1869],{"class":1494},[1053,7007,7008],{"class":1055,"line":1140},[1053,7009,1110],{"emptyLinePlaceholder":1109},[1053,7011,7012,7014,7016,7018,7020,7022,7024,7026,7028,7030,7032,7034],{"class":1055,"line":1145},[1053,7013,6123],{"class":1769},[1053,7015,6126],{"class":6082},[1053,7017,6129],{"class":1769},[1053,7019,4135],{"class":1861},[1053,7021,6134],{"class":1494},[1053,7023,4037],{"class":6137},[1053,7025,6140],{"class":1494},[1053,7027,1553],{"class":1422},[1053,7029,6145],{"class":1494},[1053,7031,4160],{"class":1861},[1053,7033,6150],{"class":1494},[1053,7035,6153],{"class":1769},[1053,7037,7038,7040,7042,7045,7047,7049],{"class":1055,"line":1151},[1053,7039,6158],{"class":1235},[1053,7041,4135],{"class":1861},[1053,7043,7044],{"class":1070},"Testing ",[1053,7046,6166],{"class":6137},[1053,7048,6169],{"class":1070},[1053,7050,4141],{"class":1861},[1053,7052,7053],{"class":1055,"line":1163},[1053,7054,6176],{"class":1509},[1053,7056,7057,7059,7061,7063,7065,7067,7069,7071,7073],{"class":1055,"line":1168},[1053,7058,6242],{"class":1769},[1053,7060,3512],{"class":1494},[1053,7062,6508],{"class":1422},[1053,7064,4135],{"class":1861},[1053,7066,6186],{"class":1070},[1053,7068,6166],{"class":6137},[1053,7070,4160],{"class":1861},[1053,7072,6257],{"class":1494},[1053,7074,6260],{"class":1769},[1053,7076,7077,7080,7082,7084,7086],{"class":1055,"line":1181},[1053,7078,7079],{"class":1235},"        cd",[1053,7081,4135],{"class":1861},[1053,7083,6186],{"class":1070},[1053,7085,6166],{"class":6137},[1053,7087,4141],{"class":1861},[1053,7089,7090],{"class":1055,"line":1186},[1053,7091,7092],{"class":1509},"        \n",[1053,7094,7095],{"class":1055,"line":1192},[1053,7096,7097],{"class":1059},"        # Activate virtual environment\n",[1053,7099,7100,7103],{"class":1055,"line":1995},[1053,7101,7102],{"class":1235},"        source",[1053,7104,1375],{"class":1070},[1053,7106,7107],{"class":1055,"line":2007},[1053,7108,7092],{"class":1509},[1053,7110,7111],{"class":1055,"line":2019},[1053,7112,7113],{"class":1059},"        # Run tests\n",[1053,7115,7116,7118,7120,7122,7124,7126,7128,7130],{"class":1055,"line":2031},[1053,7117,6440],{"class":1769},[1053,7119,3512],{"class":1494},[1053,7121,6247],{"class":1422},[1053,7123,4135],{"class":1861},[1053,7125,6299],{"class":1070},[1053,7127,4160],{"class":1861},[1053,7129,6257],{"class":1494},[1053,7131,6260],{"class":1769},[1053,7133,7134,7137,7139],{"class":1055,"line":2043},[1053,7135,7136],{"class":1066},"            python",[1053,7138,1464],{"class":1070},[1053,7140,7141],{"class":1070}," test\n",[1053,7143,7144],{"class":1055,"line":2049},[1053,7145,6516],{"class":1769},[1053,7147,7148],{"class":1055,"line":2054},[1053,7149,7092],{"class":1509},[1053,7151,7152],{"class":1055,"line":2064},[1053,7153,7154],{"class":1066},"        deactivate\n",[1053,7156,7157,7159],{"class":1055,"line":2076},[1053,7158,7079],{"class":1235},[1053,7160,6335],{"class":1070},[1053,7162,7163],{"class":1055,"line":2088},[1053,7164,6277],{"class":1769},[1053,7166,7167],{"class":1055,"line":2100},[1053,7168,6340],{"class":1769},[1053,7170,7171],{"class":1055,"line":2105},[1053,7172,1110],{"emptyLinePlaceholder":1109},[1053,7174,7175,7177,7179,7182],{"class":1055,"line":2110},[1053,7176,6061],{"class":1235},[1053,7178,4135],{"class":1861},[1053,7180,7181],{"class":1070},"All tests completed!",[1053,7183,4141],{"class":1861},[1030,7185,7187],{"id":7186},"runtime-environment-configuration","Runtime Environment Configuration",[1035,7189,7191],{"id":7190},"_1-production-docker-compose","1. Production Docker Compose",[1043,7193,7195],{"className":4005,"code":7194,"language":4007,"meta":1048,"style":1048},"# docker-compose.prod.yml\nversion: '3.8'\n\nservices:\n  # Production PostgreSQL with replication\n  postgres-master:\n    image: postgres:15-alpine\n    environment:\n      POSTGRES_DB: microservices_db\n      POSTGRES_USER: postgres\n      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}\n      POSTGRES_REPLICATION_USER: replicator\n      POSTGRES_REPLICATION_PASSWORD: ${POSTGRES_REPLICATION_PASSWORD}\n    volumes:\n      - postgres_master_data:/var/lib/postgresql/data\n      - ./infrastructure/docker/postgres/postgresql.conf:/etc/postgresql/postgresql.conf\n      - ./infrastructure/docker/postgres/pg_hba.conf:/etc/postgresql/pg_hba.conf\n    command: postgres -c config_file=/etc/postgresql/postgresql.conf\n    networks:\n      - microservices-network\n\n  postgres-slave:\n    image: postgres:15-alpine\n    environment:\n      POSTGRES_MASTER_SERVICE: postgres-master\n      POSTGRES_SLAVE_USER: replicator\n      POSTGRES_SLAVE_PASSWORD: ${POSTGRES_REPLICATION_PASSWORD}\n    volumes:\n      - postgres_slave_data:/var/lib/postgresql/data\n    depends_on:\n      - postgres-master\n    networks:\n      - microservices-network\n\n  # Redis Cluster\n  redis-master:\n    image: redis:7-alpine\n    command: redis-server --appendonly yes --requirepass ${REDIS_PASSWORD}\n    volumes:\n      - redis_master_data:/data\n    networks:\n      - microservices-network\n\n  redis-slave:\n    image: redis:7-alpine\n    command: redis-server --slaveof redis-master 6379 --requirepass ${REDIS_PASSWORD}\n    volumes:\n      - redis_slave_data:/data\n    depends_on:\n      - redis-master\n    networks:\n      - microservices-network\n\n  # Production services with scaling\n  user-service:\n    image: user-service:${VERSION}\n    environment:\n      - DEBUG=0\n      - DB_HOST=postgres-master\n      - DB_NAME=user_service_db\n      - DB_USER=user_service_user\n      - DB_PASSWORD=${USER_SERVICE_DB_PASSWORD}\n      - REDIS_URL=redis://redis-master:6379/0\n      - REDIS_PASSWORD=${REDIS_PASSWORD}\n    deploy:\n      replicas: 3\n      resources:\n        limits:\n          cpus: '0.5'\n          memory: 512M\n        reservations:\n          cpus: '0.25'\n          memory: 256M\n    networks:\n      - microservices-network\n    healthcheck:\n      test: [\"CMD\", \"curl\", \"-f\", \"http://localhost:8000/health/\"]\n      interval: 30s\n      timeout: 10s\n      retries: 3\n\nnetworks:\n  microservices-network:\n    driver: bridge\n\nvolumes:\n  postgres_master_data:\n  postgres_slave_data:\n  redis_master_data:\n  redis_slave_data:\n",[1050,7196,7197,7202,7214,7218,7224,7229,7236,7244,7250,7258,7266,7275,7285,7295,7301,7308,7315,7322,7331,7338,7345,7349,7356,7364,7370,7380,7389,7398,7404,7411,7417,7423,7429,7435,7439,7444,7451,7459,7468,7474,7481,7487,7493,7497,7504,7512,7521,7527,7534,7540,7547,7553,7559,7563,7568,7574,7583,7589,7596,7603,7609,7616,7623,7630,7637,7644,7654,7661,7668,7682,7692,7699,7712,7721,7727,7733,7739,7782,7790,7798,7806,7810,7817,7824,7834,7838,7844,7851,7858,7865],{"__ignoreMap":1048},[1053,7198,7199],{"class":1055,"line":1056},[1053,7200,7201],{"class":1059},"# docker-compose.prod.yml\n",[1053,7203,7204,7206,7208,7210,7212],{"class":1055,"line":1063},[1053,7205,3092],{"class":4019},[1053,7207,1539],{"class":1494},[1053,7209,2317],{"class":1861},[1053,7211,4026],{"class":1070},[1053,7213,2323],{"class":1861},[1053,7215,7216],{"class":1055,"line":1080},[1053,7217,1110],{"emptyLinePlaceholder":1109},[1053,7219,7220,7222],{"class":1055,"line":1086},[1053,7221,4037],{"class":4019},[1053,7223,4040],{"class":1494},[1053,7225,7226],{"class":1055,"line":1106},[1053,7227,7228],{"class":1059},"  # Production PostgreSQL with replication\n",[1053,7230,7231,7234],{"class":1055,"line":1113},[1053,7232,7233],{"class":4019},"  postgres-master",[1053,7235,4040],{"class":1494},[1053,7237,7238,7240,7242],{"class":1055,"line":1119},[1053,7239,4057],{"class":4019},[1053,7241,1539],{"class":1494},[1053,7243,4062],{"class":1070},[1053,7245,7246,7248],{"class":1055,"line":1134},[1053,7247,4067],{"class":4019},[1053,7249,4040],{"class":1494},[1053,7251,7252,7254,7256],{"class":1055,"line":1140},[1053,7253,4074],{"class":4019},[1053,7255,1539],{"class":1494},[1053,7257,4079],{"class":1070},[1053,7259,7260,7262,7264],{"class":1055,"line":1145},[1053,7261,4084],{"class":4019},[1053,7263,1539],{"class":1494},[1053,7265,4089],{"class":1070},[1053,7267,7268,7270,7272],{"class":1055,"line":1151},[1053,7269,4094],{"class":4019},[1053,7271,1539],{"class":1494},[1053,7273,7274],{"class":1070}," ${POSTGRES_PASSWORD}\n",[1053,7276,7277,7280,7282],{"class":1055,"line":1163},[1053,7278,7279],{"class":4019},"      POSTGRES_REPLICATION_USER",[1053,7281,1539],{"class":1494},[1053,7283,7284],{"class":1070}," replicator\n",[1053,7286,7287,7290,7292],{"class":1055,"line":1168},[1053,7288,7289],{"class":4019},"      POSTGRES_REPLICATION_PASSWORD",[1053,7291,1539],{"class":1494},[1053,7293,7294],{"class":1070}," ${POSTGRES_REPLICATION_PASSWORD}\n",[1053,7296,7297,7299],{"class":1055,"line":1181},[1053,7298,4104],{"class":4019},[1053,7300,4040],{"class":1494},[1053,7302,7303,7305],{"class":1055,"line":1186},[1053,7304,4111],{"class":1494},[1053,7306,7307],{"class":1070}," postgres_master_data:/var/lib/postgresql/data\n",[1053,7309,7310,7312],{"class":1055,"line":1192},[1053,7311,4111],{"class":1494},[1053,7313,7314],{"class":1070}," ./infrastructure/docker/postgres/postgresql.conf:/etc/postgresql/postgresql.conf\n",[1053,7316,7317,7319],{"class":1055,"line":1995},[1053,7318,4111],{"class":1494},[1053,7320,7321],{"class":1070}," ./infrastructure/docker/postgres/pg_hba.conf:/etc/postgresql/pg_hba.conf\n",[1053,7323,7324,7326,7328],{"class":1055,"line":2007},[1053,7325,4231],{"class":4019},[1053,7327,1539],{"class":1494},[1053,7329,7330],{"class":1070}," postgres -c config_file=/etc/postgresql/postgresql.conf\n",[1053,7332,7333,7336],{"class":1055,"line":2019},[1053,7334,7335],{"class":4019},"    networks",[1053,7337,4040],{"class":1494},[1053,7339,7340,7342],{"class":1055,"line":2031},[1053,7341,4111],{"class":1494},[1053,7343,7344],{"class":1070}," microservices-network\n",[1053,7346,7347],{"class":1055,"line":2043},[1053,7348,1110],{"emptyLinePlaceholder":1109},[1053,7350,7351,7354],{"class":1055,"line":2049},[1053,7352,7353],{"class":4019},"  postgres-slave",[1053,7355,4040],{"class":1494},[1053,7357,7358,7360,7362],{"class":1055,"line":2054},[1053,7359,4057],{"class":4019},[1053,7361,1539],{"class":1494},[1053,7363,4062],{"class":1070},[1053,7365,7366,7368],{"class":1055,"line":2064},[1053,7367,4067],{"class":4019},[1053,7369,4040],{"class":1494},[1053,7371,7372,7375,7377],{"class":1055,"line":2076},[1053,7373,7374],{"class":4019},"      POSTGRES_MASTER_SERVICE",[1053,7376,1539],{"class":1494},[1053,7378,7379],{"class":1070}," postgres-master\n",[1053,7381,7382,7385,7387],{"class":1055,"line":2088},[1053,7383,7384],{"class":4019},"      POSTGRES_SLAVE_USER",[1053,7386,1539],{"class":1494},[1053,7388,7284],{"class":1070},[1053,7390,7391,7394,7396],{"class":1055,"line":2100},[1053,7392,7393],{"class":4019},"      POSTGRES_SLAVE_PASSWORD",[1053,7395,1539],{"class":1494},[1053,7397,7294],{"class":1070},[1053,7399,7400,7402],{"class":1055,"line":2105},[1053,7401,4104],{"class":4019},[1053,7403,4040],{"class":1494},[1053,7405,7406,7408],{"class":1055,"line":2110},[1053,7407,4111],{"class":1494},[1053,7409,7410],{"class":1070}," postgres_slave_data:/var/lib/postgresql/data\n",[1053,7412,7413,7415],{"class":1055,"line":2120},[1053,7414,4649],{"class":4019},[1053,7416,4040],{"class":1494},[1053,7418,7419,7421],{"class":1055,"line":2132},[1053,7420,4111],{"class":1494},[1053,7422,7379],{"class":1070},[1053,7424,7425,7427],{"class":1055,"line":2137},[1053,7426,7335],{"class":4019},[1053,7428,4040],{"class":1494},[1053,7430,7431,7433],{"class":1055,"line":2142},[1053,7432,4111],{"class":1494},[1053,7434,7344],{"class":1070},[1053,7436,7437],{"class":1055,"line":2164},[1053,7438,1110],{"emptyLinePlaceholder":1109},[1053,7440,7441],{"class":1055,"line":2169},[1053,7442,7443],{"class":1059},"  # Redis Cluster\n",[1053,7445,7446,7449],{"class":1055,"line":2179},[1053,7447,7448],{"class":4019},"  redis-master",[1053,7450,4040],{"class":1494},[1053,7452,7453,7455,7457],{"class":1055,"line":2191},[1053,7454,4057],{"class":4019},[1053,7456,1539],{"class":1494},[1053,7458,4226],{"class":1070},[1053,7460,7461,7463,7465],{"class":1055,"line":2203},[1053,7462,4231],{"class":4019},[1053,7464,1539],{"class":1494},[1053,7466,7467],{"class":1070}," redis-server --appendonly yes --requirepass ${REDIS_PASSWORD}\n",[1053,7469,7470,7472],{"class":1055,"line":2215},[1053,7471,4104],{"class":4019},[1053,7473,4040],{"class":1494},[1053,7475,7476,7478],{"class":1055,"line":2227},[1053,7477,4111],{"class":1494},[1053,7479,7480],{"class":1070}," redis_master_data:/data\n",[1053,7482,7483,7485],{"class":1055,"line":2239},[1053,7484,7335],{"class":4019},[1053,7486,4040],{"class":1494},[1053,7488,7489,7491],{"class":1055,"line":2251},[1053,7490,4111],{"class":1494},[1053,7492,7344],{"class":1070},[1053,7494,7495],{"class":1055,"line":2263},[1053,7496,1110],{"emptyLinePlaceholder":1109},[1053,7498,7499,7502],{"class":1055,"line":2275},[1053,7500,7501],{"class":4019},"  redis-slave",[1053,7503,4040],{"class":1494},[1053,7505,7506,7508,7510],{"class":1055,"line":2287},[1053,7507,4057],{"class":4019},[1053,7509,1539],{"class":1494},[1053,7511,4226],{"class":1070},[1053,7513,7514,7516,7518],{"class":1055,"line":2299},[1053,7515,4231],{"class":4019},[1053,7517,1539],{"class":1494},[1053,7519,7520],{"class":1070}," redis-server --slaveof redis-master 6379 --requirepass ${REDIS_PASSWORD}\n",[1053,7522,7523,7525],{"class":1055,"line":2304},[1053,7524,4104],{"class":4019},[1053,7526,4040],{"class":1494},[1053,7528,7529,7531],{"class":1055,"line":2309},[1053,7530,4111],{"class":1494},[1053,7532,7533],{"class":1070}," redis_slave_data:/data\n",[1053,7535,7536,7538],{"class":1055,"line":2326},[1053,7537,4649],{"class":4019},[1053,7539,4040],{"class":1494},[1053,7541,7542,7544],{"class":1055,"line":2331},[1053,7543,4111],{"class":1494},[1053,7545,7546],{"class":1070}," redis-master\n",[1053,7548,7549,7551],{"class":1055,"line":2337},[1053,7550,7335],{"class":4019},[1053,7552,4040],{"class":1494},[1053,7554,7555,7557],{"class":1055,"line":2348},[1053,7556,4111],{"class":1494},[1053,7558,7344],{"class":1070},[1053,7560,7561],{"class":1055,"line":2362},[1053,7562,1110],{"emptyLinePlaceholder":1109},[1053,7564,7565],{"class":1055,"line":2384},[1053,7566,7567],{"class":1059},"  # Production services with scaling\n",[1053,7569,7570,7572],{"class":1055,"line":2423},[1053,7571,4553],{"class":4019},[1053,7573,4040],{"class":1494},[1053,7575,7576,7578,7580],{"class":1055,"line":2460},[1053,7577,4057],{"class":4019},[1053,7579,1539],{"class":1494},[1053,7581,7582],{"class":1070}," user-service:${VERSION}\n",[1053,7584,7585,7587],{"class":1055,"line":2497},[1053,7586,4067],{"class":4019},[1053,7588,4040],{"class":1494},[1053,7590,7591,7593],{"class":1055,"line":2534},[1053,7592,4111],{"class":1494},[1053,7594,7595],{"class":1070}," DEBUG=0\n",[1053,7597,7598,7600],{"class":1055,"line":2571},[1053,7599,4111],{"class":1494},[1053,7601,7602],{"class":1070}," DB_HOST=postgres-master\n",[1053,7604,7605,7607],{"class":1055,"line":2585},[1053,7606,4111],{"class":1494},[1053,7608,4592],{"class":1070},[1053,7610,7611,7613],{"class":1055,"line":2603},[1053,7612,4111],{"class":1494},[1053,7614,7615],{"class":1070}," DB_USER=user_service_user\n",[1053,7617,7618,7620],{"class":1055,"line":2620},[1053,7619,4111],{"class":1494},[1053,7621,7622],{"class":1070}," DB_PASSWORD=${USER_SERVICE_DB_PASSWORD}\n",[1053,7624,7625,7627],{"class":1055,"line":2626},[1053,7626,4111],{"class":1494},[1053,7628,7629],{"class":1070}," REDIS_URL=redis://redis-master:6379/0\n",[1053,7631,7632,7634],{"class":1055,"line":2632},[1053,7633,4111],{"class":1494},[1053,7635,7636],{"class":1070}," REDIS_PASSWORD=${REDIS_PASSWORD}\n",[1053,7638,7639,7642],{"class":1055,"line":2638},[1053,7640,7641],{"class":4019},"    deploy",[1053,7643,4040],{"class":1494},[1053,7645,7646,7649,7651],{"class":1055,"line":2643},[1053,7647,7648],{"class":4019},"      replicas",[1053,7650,1539],{"class":1494},[1053,7652,7653],{"class":1561}," 3\n",[1053,7655,7656,7659],{"class":1055,"line":2649},[1053,7657,7658],{"class":4019},"      resources",[1053,7660,4040],{"class":1494},[1053,7662,7663,7666],{"class":1055,"line":2659},[1053,7664,7665],{"class":4019},"        limits",[1053,7667,4040],{"class":1494},[1053,7669,7670,7673,7675,7677,7680],{"class":1055,"line":2672},[1053,7671,7672],{"class":4019},"          cpus",[1053,7674,1539],{"class":1494},[1053,7676,2317],{"class":1861},[1053,7678,7679],{"class":1070},"0.5",[1053,7681,2323],{"class":1861},[1053,7683,7684,7687,7689],{"class":1055,"line":2693},[1053,7685,7686],{"class":4019},"          memory",[1053,7688,1539],{"class":1494},[1053,7690,7691],{"class":1070}," 512M\n",[1053,7693,7694,7697],{"class":1055,"line":2730},[1053,7695,7696],{"class":4019},"        reservations",[1053,7698,4040],{"class":1494},[1053,7700,7701,7703,7705,7707,7710],{"class":1055,"line":2743},[1053,7702,7672],{"class":4019},[1053,7704,1539],{"class":1494},[1053,7706,2317],{"class":1861},[1053,7708,7709],{"class":1070},"0.25",[1053,7711,2323],{"class":1861},[1053,7713,7714,7716,7718],{"class":1055,"line":2764},[1053,7715,7686],{"class":4019},[1053,7717,1539],{"class":1494},[1053,7719,7720],{"class":1070}," 256M\n",[1053,7722,7723,7725],{"class":1055,"line":2769},[1053,7724,7335],{"class":4019},[1053,7726,4040],{"class":1494},[1053,7728,7729,7731],{"class":1055,"line":2774},[1053,7730,4111],{"class":1494},[1053,7732,7344],{"class":1070},[1053,7734,7735,7737],{"class":1055,"line":2779},[1053,7736,4146],{"class":4019},[1053,7738,4040],{"class":1494},[1053,7740,7741,7743,7745,7747,7749,7751,7753,7755,7757,7760,7762,7764,7766,7769,7771,7773,7775,7778,7780],{"class":1055,"line":2784},[1053,7742,4153],{"class":4019},[1053,7744,1539],{"class":1494},[1053,7746,3512],{"class":1494},[1053,7748,4160],{"class":1861},[1053,7750,3965],{"class":1070},[1053,7752,4160],{"class":1861},[1053,7754,1682],{"class":1494},[1053,7756,4135],{"class":1861},[1053,7758,7759],{"class":1070},"curl",[1053,7761,4160],{"class":1861},[1053,7763,1682],{"class":1494},[1053,7765,4135],{"class":1861},[1053,7767,7768],{"class":1070},"-f",[1053,7770,4160],{"class":1861},[1053,7772,1682],{"class":1494},[1053,7774,4135],{"class":1861},[1053,7776,7777],{"class":1070},"http://localhost:8000/health/",[1053,7779,4160],{"class":1861},[1053,7781,2046],{"class":1494},[1053,7783,7784,7786,7788],{"class":1055,"line":2790},[1053,7785,4181],{"class":4019},[1053,7787,1539],{"class":1494},[1053,7789,4464],{"class":1070},[1053,7791,7792,7794,7796],{"class":1055,"line":2800},[1053,7793,4191],{"class":4019},[1053,7795,1539],{"class":1494},[1053,7797,4186],{"class":1070},[1053,7799,7800,7802,7804],{"class":1055,"line":2814},[1053,7801,4201],{"class":4019},[1053,7803,1539],{"class":1494},[1053,7805,7653],{"class":1561},[1053,7807,7808],{"class":1055,"line":2826},[1053,7809,1110],{"emptyLinePlaceholder":1109},[1053,7811,7812,7815],{"class":1055,"line":2832},[1053,7813,7814],{"class":4019},"networks",[1053,7816,4040],{"class":1494},[1053,7818,7819,7822],{"class":1055,"line":2846},[1053,7820,7821],{"class":4019},"  microservices-network",[1053,7823,4040],{"class":1494},[1053,7825,7826,7829,7831],{"class":1055,"line":2858},[1053,7827,7828],{"class":4019},"    driver",[1053,7830,1539],{"class":1494},[1053,7832,7833],{"class":1070}," bridge\n",[1053,7835,7836],{"class":1055,"line":2863},[1053,7837,1110],{"emptyLinePlaceholder":1109},[1053,7839,7840,7842],{"class":1055,"line":2884},[1053,7841,5232],{"class":4019},[1053,7843,4040],{"class":1494},[1053,7845,7846,7849],{"class":1055,"line":2900},[1053,7847,7848],{"class":4019},"  postgres_master_data",[1053,7850,4040],{"class":1494},[1053,7852,7853,7856],{"class":1055,"line":2914},[1053,7854,7855],{"class":4019},"  postgres_slave_data",[1053,7857,4040],{"class":1494},[1053,7859,7860,7863],{"class":1055,"line":2926},[1053,7861,7862],{"class":4019},"  redis_master_data",[1053,7864,4040],{"class":1494},[1053,7866,7867,7870],{"class":1055,"line":2936},[1053,7868,7869],{"class":4019},"  redis_slave_data",[1053,7871,4040],{"class":1494},[1035,7873,7875],{"id":7874},"_2-environment-variables-management","2. Environment Variables Management",[1043,7877,7879],{"className":1045,"code":7878,"language":1047,"meta":1048,"style":1048},"# .env.production\nDEBUG=False\nSECRET_KEY=your-super-secret-production-key\nPOSTGRES_PASSWORD=secure-postgres-password\nPOSTGRES_REPLICATION_PASSWORD=secure-replication-password\nREDIS_PASSWORD=secure-redis-password\nUSER_SERVICE_DB_PASSWORD=secure-user-service-password\nPRODUCT_SERVICE_DB_PASSWORD=secure-product-service-password\nORDER_SERVICE_DB_PASSWORD=secure-order-service-password\nPAYMENT_SERVICE_DB_PASSWORD=secure-payment-service-password\nSERVICE_SECRET_TOKEN=secure-service-communication-token\nVERSION=1.0.0\n",[1050,7880,7881,7886,7895,7904,7914,7924,7934,7944,7954,7964,7974,7983],{"__ignoreMap":1048},[1053,7882,7883],{"class":1055,"line":1056},[1053,7884,7885],{"class":1059},"# .env.production\n",[1053,7887,7888,7890,7892],{"class":1055,"line":1063},[1053,7889,1491],{"class":6082},[1053,7891,1495],{"class":1494},[1053,7893,7894],{"class":1070},"False\n",[1053,7896,7897,7899,7901],{"class":1055,"line":1080},[1053,7898,1504],{"class":6082},[1053,7900,1495],{"class":1494},[1053,7902,7903],{"class":1070},"your-super-secret-production-key\n",[1053,7905,7906,7909,7911],{"class":1055,"line":1086},[1053,7907,7908],{"class":6082},"POSTGRES_PASSWORD",[1053,7910,1495],{"class":1494},[1053,7912,7913],{"class":1070},"secure-postgres-password\n",[1053,7915,7916,7919,7921],{"class":1055,"line":1106},[1053,7917,7918],{"class":6082},"POSTGRES_REPLICATION_PASSWORD",[1053,7920,1495],{"class":1494},[1053,7922,7923],{"class":1070},"secure-replication-password\n",[1053,7925,7926,7929,7931],{"class":1055,"line":1113},[1053,7927,7928],{"class":6082},"REDIS_PASSWORD",[1053,7930,1495],{"class":1494},[1053,7932,7933],{"class":1070},"secure-redis-password\n",[1053,7935,7936,7939,7941],{"class":1055,"line":1119},[1053,7937,7938],{"class":6082},"USER_SERVICE_DB_PASSWORD",[1053,7940,1495],{"class":1494},[1053,7942,7943],{"class":1070},"secure-user-service-password\n",[1053,7945,7946,7949,7951],{"class":1055,"line":1134},[1053,7947,7948],{"class":6082},"PRODUCT_SERVICE_DB_PASSWORD",[1053,7950,1495],{"class":1494},[1053,7952,7953],{"class":1070},"secure-product-service-password\n",[1053,7955,7956,7959,7961],{"class":1055,"line":1140},[1053,7957,7958],{"class":6082},"ORDER_SERVICE_DB_PASSWORD",[1053,7960,1495],{"class":1494},[1053,7962,7963],{"class":1070},"secure-order-service-password\n",[1053,7965,7966,7969,7971],{"class":1055,"line":1145},[1053,7967,7968],{"class":6082},"PAYMENT_SERVICE_DB_PASSWORD",[1053,7970,1495],{"class":1494},[1053,7972,7973],{"class":1070},"secure-payment-service-password\n",[1053,7975,7976,7978,7980],{"class":1055,"line":1151},[1053,7977,1652],{"class":6082},[1053,7979,1495],{"class":1494},[1053,7981,7982],{"class":1070},"secure-service-communication-token\n",[1053,7984,7985,7988,7990],{"class":1055,"line":1163},[1053,7986,7987],{"class":6082},"VERSION",[1053,7989,1495],{"class":1494},[1053,7991,7992],{"class":1070},"1.0.0\n",[1035,7994,7996],{"id":7995},"_3-health-check-implementation","3. Health Check Implementation",[1043,7998,8000],{"className":1477,"code":7999,"language":1461,"meta":1048,"style":1048},"# shared/health_check.py\nfrom django.http import JsonResponse\nfrom django.db import connection\nfrom django.core.cache import cache\nimport redis\nimport pika\nfrom django.conf import settings\n\ndef comprehensive_health_check(request):\n    \"\"\"Comprehensive health check for microservices\"\"\"\n    health_status = {\n        'status': 'healthy',\n        'service': settings.SERVICE_NAME,\n        'version': settings.SERVICE_VERSION,\n        'checks': {}\n    }\n    \n    # Database check\n    try:\n        with connection.cursor() as cursor:\n            cursor.execute(\"SELECT 1\")\n        health_status['checks']['database'] = 'healthy'\n    except Exception as e:\n        health_status['checks']['database'] = f'unhealthy: {str(e)}'\n        health_status['status'] = 'unhealthy'\n    \n    # Redis check\n    try:\n        cache.set('health_check', 'ok', 10)\n        cache.get('health_check')\n        health_status['checks']['redis'] = 'healthy'\n    except Exception as e:\n        health_status['checks']['redis'] = f'unhealthy: {str(e)}'\n        health_status['status'] = 'unhealthy'\n    \n    # RabbitMQ check\n    try:\n        connection_params = pika.URLParameters(settings.RABBITMQ_URL)\n        connection = pika.BlockingConnection(connection_params)\n        connection.close()\n        health_status['checks']['rabbitmq'] = 'healthy'\n    except Exception as e:\n        health_status['checks']['rabbitmq'] = f'unhealthy: {str(e)}'\n        health_status['status'] = 'unhealthy'\n    \n    status_code = 200 if health_status['status'] == 'healthy' else 503\n    return JsonResponse(health_status, status=status_code)\n",[1050,8001,8002,8007,8023,8039,8060,8067,8074,8090,8094,8111,8123,8132,8152,8172,8190,8204,8208,8212,8217,8224,8248,8269,8303,8318,8365,8388,8392,8397,8403,8437,8456,8486,8498,8540,8562,8566,8571,8577,8603,8624,8637,8668,8680,8722,8744,8748,8789],{"__ignoreMap":1048},[1053,8003,8004],{"class":1055,"line":1056},[1053,8005,8006],{"class":1059},"# shared/health_check.py\n",[1053,8008,8009,8011,8013,8015,8018,8020],{"class":1055,"line":1063},[1053,8010,1778],{"class":1769},[1053,8012,1406],{"class":1509},[1053,8014,1688],{"class":1494},[1053,8016,8017],{"class":1509},"http ",[1053,8019,1770],{"class":1769},[1053,8021,8022],{"class":1509}," JsonResponse\n",[1053,8024,8025,8027,8029,8031,8034,8036],{"class":1055,"line":1080},[1053,8026,1778],{"class":1769},[1053,8028,1406],{"class":1509},[1053,8030,1688],{"class":1494},[1053,8032,8033],{"class":1509},"db ",[1053,8035,1770],{"class":1769},[1053,8037,8038],{"class":1509}," connection\n",[1053,8040,8041,8043,8045,8047,8050,8052,8055,8057],{"class":1055,"line":1086},[1053,8042,1778],{"class":1769},[1053,8044,1406],{"class":1509},[1053,8046,1688],{"class":1494},[1053,8048,8049],{"class":1509},"core",[1053,8051,1688],{"class":1494},[1053,8053,8054],{"class":1509},"cache ",[1053,8056,1770],{"class":1769},[1053,8058,8059],{"class":1509}," cache\n",[1053,8061,8062,8064],{"class":1055,"line":1106},[1053,8063,1770],{"class":1769},[1053,8065,8066],{"class":1509}," redis\n",[1053,8068,8069,8071],{"class":1055,"line":1113},[1053,8070,1770],{"class":1769},[1053,8072,8073],{"class":1509}," pika\n",[1053,8075,8076,8078,8080,8082,8085,8087],{"class":1055,"line":1119},[1053,8077,1778],{"class":1769},[1053,8079,1406],{"class":1509},[1053,8081,1688],{"class":1494},[1053,8083,8084],{"class":1509},"conf ",[1053,8086,1770],{"class":1769},[1053,8088,8089],{"class":1509}," settings\n",[1053,8091,8092],{"class":1055,"line":1134},[1053,8093,1110],{"emptyLinePlaceholder":1109},[1053,8095,8096,8099,8102,8104,8108],{"class":1055,"line":1140},[1053,8097,8098],{"class":3176},"def",[1053,8100,8101],{"class":5293}," comprehensive_health_check",[1053,8103,1817],{"class":1494},[1053,8105,8107],{"class":8106},"sCyAa","request",[1053,8109,8110],{"class":1494},"):\n",[1053,8112,8113,8117,8120],{"class":1055,"line":1145},[1053,8114,8116],{"class":8115},"sm7ve","    \"\"\"",[1053,8118,8119],{"class":6904},"Comprehensive health check for microservices",[1053,8121,8122],{"class":8115},"\"\"\"\n",[1053,8124,8125,8128,8130],{"class":1055,"line":1151},[1053,8126,8127],{"class":1509},"    health_status ",[1053,8129,1495],{"class":1494},[1053,8131,2345],{"class":1494},[1053,8133,8134,8136,8139,8141,8143,8145,8148,8150],{"class":1055,"line":1163},[1053,8135,2365],{"class":1861},[1053,8137,8138],{"class":1070},"status",[1053,8140,1862],{"class":1861},[1053,8142,1539],{"class":1494},[1053,8144,2317],{"class":1861},[1053,8146,8147],{"class":1070},"healthy",[1053,8149,1862],{"class":1861},[1053,8151,1981],{"class":1494},[1053,8153,8154,8156,8158,8160,8162,8165,8167,8170],{"class":1055,"line":1168},[1053,8155,2365],{"class":1861},[1053,8157,1661],{"class":1070},[1053,8159,1862],{"class":1861},[1053,8161,1539],{"class":1494},[1053,8163,8164],{"class":1509}," settings",[1053,8166,1688],{"class":1494},[1053,8168,3575],{"class":8169},"sFGJz",[1053,8171,1981],{"class":1494},[1053,8173,8174,8176,8178,8180,8182,8184,8186,8188],{"class":1055,"line":1181},[1053,8175,2365],{"class":1861},[1053,8177,3092],{"class":1070},[1053,8179,1862],{"class":1861},[1053,8181,1539],{"class":1494},[1053,8183,8164],{"class":1509},[1053,8185,1688],{"class":1494},[1053,8187,3590],{"class":8169},[1053,8189,1981],{"class":1494},[1053,8191,8192,8194,8197,8199,8201],{"class":1055,"line":1186},[1053,8193,2365],{"class":1861},[1053,8195,8196],{"class":1070},"checks",[1053,8198,1862],{"class":1861},[1053,8200,1539],{"class":1494},[1053,8202,8203],{"class":1494}," {}\n",[1053,8205,8206],{"class":1055,"line":1192},[1053,8207,2629],{"class":1494},[1053,8209,8210],{"class":1055,"line":1995},[1053,8211,6176],{"class":1509},[1053,8213,8214],{"class":1055,"line":2007},[1053,8215,8216],{"class":1059},"    # Database check\n",[1053,8218,8219,8222],{"class":1055,"line":2019},[1053,8220,8221],{"class":1769},"    try",[1053,8223,4040],{"class":1494},[1053,8225,8226,8229,8232,8234,8237,8240,8243,8246],{"class":1055,"line":2031},[1053,8227,8228],{"class":1769},"        with",[1053,8230,8231],{"class":1509}," connection",[1053,8233,1688],{"class":1494},[1053,8235,8236],{"class":1813},"cursor",[1053,8238,8239],{"class":1494},"()",[1053,8241,8242],{"class":1769}," as",[1053,8244,8245],{"class":1509}," cursor",[1053,8247,4040],{"class":1494},[1053,8249,8250,8253,8255,8258,8260,8262,8265,8267],{"class":1055,"line":2043},[1053,8251,8252],{"class":1509},"            cursor",[1053,8254,1688],{"class":1494},[1053,8256,8257],{"class":1813},"execute",[1053,8259,1817],{"class":1494},[1053,8261,4160],{"class":1861},[1053,8263,8264],{"class":1070},"SELECT 1",[1053,8266,4160],{"class":1861},[1053,8268,1869],{"class":1494},[1053,8270,8271,8274,8276,8278,8280,8282,8285,8287,8290,8292,8295,8297,8299,8301],{"class":1055,"line":2049},[1053,8272,8273],{"class":1509},"        health_status",[1053,8275,6140],{"class":1494},[1053,8277,1862],{"class":1861},[1053,8279,8196],{"class":1070},[1053,8281,1862],{"class":1861},[1053,8283,8284],{"class":1494},"][",[1053,8286,1862],{"class":1861},[1053,8288,8289],{"class":1070},"database",[1053,8291,1862],{"class":1861},[1053,8293,8294],{"class":1494},"]",[1053,8296,1810],{"class":1494},[1053,8298,2317],{"class":1861},[1053,8300,8147],{"class":1070},[1053,8302,2323],{"class":1861},[1053,8304,8305,8308,8311,8313,8316],{"class":1055,"line":2054},[1053,8306,8307],{"class":1769},"    except",[1053,8309,8310],{"class":1906}," Exception",[1053,8312,8242],{"class":1769},[1053,8314,8315],{"class":1509}," e",[1053,8317,4040],{"class":1494},[1053,8319,8320,8322,8324,8326,8328,8330,8332,8334,8336,8338,8340,8342,8345,8348,8350,8353,8355,8358,8361,8363],{"class":1055,"line":2064},[1053,8321,8273],{"class":1509},[1053,8323,6140],{"class":1494},[1053,8325,1862],{"class":1861},[1053,8327,8196],{"class":1070},[1053,8329,1862],{"class":1861},[1053,8331,8284],{"class":1494},[1053,8333,1862],{"class":1861},[1053,8335,8289],{"class":1070},[1053,8337,1862],{"class":1861},[1053,8339,8294],{"class":1494},[1053,8341,1810],{"class":1494},[1053,8343,8344],{"class":3176}," f",[1053,8346,8347],{"class":1070},"'unhealthy: ",[1053,8349,3211],{"class":3163},[1053,8351,8352],{"class":1906},"str",[1053,8354,1817],{"class":1494},[1053,8356,8357],{"class":1813},"e",[1053,8359,8360],{"class":1494},")",[1053,8362,3180],{"class":3163},[1053,8364,2323],{"class":1070},[1053,8366,8367,8369,8371,8373,8375,8377,8379,8381,8383,8386],{"class":1055,"line":2076},[1053,8368,8273],{"class":1509},[1053,8370,6140],{"class":1494},[1053,8372,1862],{"class":1861},[1053,8374,8138],{"class":1070},[1053,8376,1862],{"class":1861},[1053,8378,8294],{"class":1494},[1053,8380,1810],{"class":1494},[1053,8382,2317],{"class":1861},[1053,8384,8385],{"class":1070},"unhealthy",[1053,8387,2323],{"class":1861},[1053,8389,8390],{"class":1055,"line":2088},[1053,8391,6176],{"class":1509},[1053,8393,8394],{"class":1055,"line":2100},[1053,8395,8396],{"class":1059},"    # Redis check\n",[1053,8398,8399,8401],{"class":1055,"line":2105},[1053,8400,8221],{"class":1769},[1053,8402,4040],{"class":1494},[1053,8404,8405,8408,8410,8412,8414,8416,8419,8421,8423,8425,8428,8430,8432,8435],{"class":1055,"line":2110},[1053,8406,8407],{"class":1509},"        cache",[1053,8409,1688],{"class":1494},[1053,8411,6049],{"class":1813},[1053,8413,1817],{"class":1494},[1053,8415,1862],{"class":1861},[1053,8417,8418],{"class":1070},"health_check",[1053,8420,1862],{"class":1861},[1053,8422,1682],{"class":1494},[1053,8424,2317],{"class":1861},[1053,8426,8427],{"class":1070},"ok",[1053,8429,1862],{"class":1861},[1053,8431,1682],{"class":1494},[1053,8433,8434],{"class":1561}," 10",[1053,8436,1869],{"class":1494},[1053,8438,8439,8441,8443,8446,8448,8450,8452,8454],{"class":1055,"line":2120},[1053,8440,8407],{"class":1509},[1053,8442,1688],{"class":1494},[1053,8444,8445],{"class":1813},"get",[1053,8447,1817],{"class":1494},[1053,8449,1862],{"class":1861},[1053,8451,8418],{"class":1070},[1053,8453,1862],{"class":1861},[1053,8455,1869],{"class":1494},[1053,8457,8458,8460,8462,8464,8466,8468,8470,8472,8474,8476,8478,8480,8482,8484],{"class":1055,"line":2132},[1053,8459,8273],{"class":1509},[1053,8461,6140],{"class":1494},[1053,8463,1862],{"class":1861},[1053,8465,8196],{"class":1070},[1053,8467,1862],{"class":1861},[1053,8469,8284],{"class":1494},[1053,8471,1862],{"class":1861},[1053,8473,1578],{"class":1070},[1053,8475,1862],{"class":1861},[1053,8477,8294],{"class":1494},[1053,8479,1810],{"class":1494},[1053,8481,2317],{"class":1861},[1053,8483,8147],{"class":1070},[1053,8485,2323],{"class":1861},[1053,8487,8488,8490,8492,8494,8496],{"class":1055,"line":2137},[1053,8489,8307],{"class":1769},[1053,8491,8310],{"class":1906},[1053,8493,8242],{"class":1769},[1053,8495,8315],{"class":1509},[1053,8497,4040],{"class":1494},[1053,8499,8500,8502,8504,8506,8508,8510,8512,8514,8516,8518,8520,8522,8524,8526,8528,8530,8532,8534,8536,8538],{"class":1055,"line":2142},[1053,8501,8273],{"class":1509},[1053,8503,6140],{"class":1494},[1053,8505,1862],{"class":1861},[1053,8507,8196],{"class":1070},[1053,8509,1862],{"class":1861},[1053,8511,8284],{"class":1494},[1053,8513,1862],{"class":1861},[1053,8515,1578],{"class":1070},[1053,8517,1862],{"class":1861},[1053,8519,8294],{"class":1494},[1053,8521,1810],{"class":1494},[1053,8523,8344],{"class":3176},[1053,8525,8347],{"class":1070},[1053,8527,3211],{"class":3163},[1053,8529,8352],{"class":1906},[1053,8531,1817],{"class":1494},[1053,8533,8357],{"class":1813},[1053,8535,8360],{"class":1494},[1053,8537,3180],{"class":3163},[1053,8539,2323],{"class":1070},[1053,8541,8542,8544,8546,8548,8550,8552,8554,8556,8558,8560],{"class":1055,"line":2164},[1053,8543,8273],{"class":1509},[1053,8545,6140],{"class":1494},[1053,8547,1862],{"class":1861},[1053,8549,8138],{"class":1070},[1053,8551,1862],{"class":1861},[1053,8553,8294],{"class":1494},[1053,8555,1810],{"class":1494},[1053,8557,2317],{"class":1861},[1053,8559,8385],{"class":1070},[1053,8561,2323],{"class":1861},[1053,8563,8564],{"class":1055,"line":2169},[1053,8565,6176],{"class":1509},[1053,8567,8568],{"class":1055,"line":2179},[1053,8569,8570],{"class":1059},"    # RabbitMQ check\n",[1053,8572,8573,8575],{"class":1055,"line":2191},[1053,8574,8221],{"class":1769},[1053,8576,4040],{"class":1494},[1053,8578,8579,8582,8584,8587,8589,8592,8594,8597,8599,8601],{"class":1055,"line":2203},[1053,8580,8581],{"class":1509},"        connection_params ",[1053,8583,1495],{"class":1494},[1053,8585,8586],{"class":1509}," pika",[1053,8588,1688],{"class":1494},[1053,8590,8591],{"class":1813},"URLParameters",[1053,8593,1817],{"class":1494},[1053,8595,8596],{"class":1813},"settings",[1053,8598,1688],{"class":1494},[1053,8600,1599],{"class":8169},[1053,8602,1869],{"class":1494},[1053,8604,8605,8608,8610,8612,8614,8617,8619,8622],{"class":1055,"line":2215},[1053,8606,8607],{"class":1509},"        connection ",[1053,8609,1495],{"class":1494},[1053,8611,8586],{"class":1509},[1053,8613,1688],{"class":1494},[1053,8615,8616],{"class":1813},"BlockingConnection",[1053,8618,1817],{"class":1494},[1053,8620,8621],{"class":1813},"connection_params",[1053,8623,1869],{"class":1494},[1053,8625,8626,8629,8631,8634],{"class":1055,"line":2227},[1053,8627,8628],{"class":1509},"        connection",[1053,8630,1688],{"class":1494},[1053,8632,8633],{"class":1813},"close",[1053,8635,8636],{"class":1494},"()\n",[1053,8638,8639,8641,8643,8645,8647,8649,8651,8653,8656,8658,8660,8662,8664,8666],{"class":1055,"line":2239},[1053,8640,8273],{"class":1509},[1053,8642,6140],{"class":1494},[1053,8644,1862],{"class":1861},[1053,8646,8196],{"class":1070},[1053,8648,1862],{"class":1861},[1053,8650,8284],{"class":1494},[1053,8652,1862],{"class":1861},[1053,8654,8655],{"class":1070},"rabbitmq",[1053,8657,1862],{"class":1861},[1053,8659,8294],{"class":1494},[1053,8661,1810],{"class":1494},[1053,8663,2317],{"class":1861},[1053,8665,8147],{"class":1070},[1053,8667,2323],{"class":1861},[1053,8669,8670,8672,8674,8676,8678],{"class":1055,"line":2251},[1053,8671,8307],{"class":1769},[1053,8673,8310],{"class":1906},[1053,8675,8242],{"class":1769},[1053,8677,8315],{"class":1509},[1053,8679,4040],{"class":1494},[1053,8681,8682,8684,8686,8688,8690,8692,8694,8696,8698,8700,8702,8704,8706,8708,8710,8712,8714,8716,8718,8720],{"class":1055,"line":2263},[1053,8683,8273],{"class":1509},[1053,8685,6140],{"class":1494},[1053,8687,1862],{"class":1861},[1053,8689,8196],{"class":1070},[1053,8691,1862],{"class":1861},[1053,8693,8284],{"class":1494},[1053,8695,1862],{"class":1861},[1053,8697,8655],{"class":1070},[1053,8699,1862],{"class":1861},[1053,8701,8294],{"class":1494},[1053,8703,1810],{"class":1494},[1053,8705,8344],{"class":3176},[1053,8707,8347],{"class":1070},[1053,8709,3211],{"class":3163},[1053,8711,8352],{"class":1906},[1053,8713,1817],{"class":1494},[1053,8715,8357],{"class":1813},[1053,8717,8360],{"class":1494},[1053,8719,3180],{"class":3163},[1053,8721,2323],{"class":1070},[1053,8723,8724,8726,8728,8730,8732,8734,8736,8738,8740,8742],{"class":1055,"line":2275},[1053,8725,8273],{"class":1509},[1053,8727,6140],{"class":1494},[1053,8729,1862],{"class":1861},[1053,8731,8138],{"class":1070},[1053,8733,1862],{"class":1861},[1053,8735,8294],{"class":1494},[1053,8737,1810],{"class":1494},[1053,8739,2317],{"class":1861},[1053,8741,8385],{"class":1070},[1053,8743,2323],{"class":1861},[1053,8745,8746],{"class":1055,"line":2287},[1053,8747,6176],{"class":1509},[1053,8749,8750,8753,8755,8758,8761,8764,8766,8768,8770,8772,8774,8777,8779,8781,8783,8786],{"class":1055,"line":2299},[1053,8751,8752],{"class":1509},"    status_code ",[1053,8754,1495],{"class":1494},[1053,8756,8757],{"class":1561}," 200",[1053,8759,8760],{"class":1769}," if",[1053,8762,8763],{"class":1509}," health_status",[1053,8765,6140],{"class":1494},[1053,8767,1862],{"class":1861},[1053,8769,8138],{"class":1070},[1053,8771,1862],{"class":1861},[1053,8773,8294],{"class":1494},[1053,8775,8776],{"class":1422}," ==",[1053,8778,2317],{"class":1861},[1053,8780,8147],{"class":1070},[1053,8782,1862],{"class":1861},[1053,8784,8785],{"class":1769}," else",[1053,8787,8788],{"class":1561}," 503\n",[1053,8790,8791,8794,8797,8799,8802,8804,8807,8809,8812],{"class":1055,"line":2304},[1053,8792,8793],{"class":1769},"    return",[1053,8795,8796],{"class":1813}," JsonResponse",[1053,8798,1817],{"class":1494},[1053,8800,8801],{"class":1813},"health_status",[1053,8803,1682],{"class":1494},[1053,8805,8806],{"class":1890}," status",[1053,8808,1495],{"class":1494},[1053,8810,8811],{"class":1813},"status_code",[1053,8813,1869],{"class":1494},[1035,8815,8817],{"id":8816},"_4-monitoring-and-logging","4. Monitoring and Logging",[1043,8819,8821],{"className":1477,"code":8820,"language":1461,"meta":1048,"style":1048},"# shared/monitoring.py\nimport logging\nimport time\nfrom django.utils.deprecation import MiddlewareMixin\nfrom prometheus_client import Counter, Histogram, generate_latest\n\n# Metrics\nREQUEST_COUNT = Counter('django_requests_total', 'Total requests', ['method', 'endpoint', 'status'])\nREQUEST_LATENCY = Histogram('django_request_duration_seconds', 'Request latency')\n\nclass MetricsMiddleware(MiddlewareMixin):\n    def process_request(self, request):\n        request.start_time = time.time()\n    \n    def process_response(self, request, response):\n        if hasattr(request, 'start_time'):\n            duration = time.time() - request.start_time\n            REQUEST_LATENCY.observe(duration)\n            REQUEST_COUNT.labels(\n                method=request.method,\n                endpoint=request.path,\n                status=response.status_code\n            ).inc()\n        \n        return response\n\ndef metrics_view(request):\n    \"\"\"Prometheus metrics endpoint\"\"\"\n    from django.http import HttpResponse\n    return HttpResponse(generate_latest(), content_type='text/plain')\n",[1050,8822,8823,8828,8835,8842,8863,8885,8889,8894,8952,8981,8985,9000,9021,9043,9047,9069,9090,9115,9132,9145,9160,9176,9191,9201,9205,9213,9217,9230,9239,9255],{"__ignoreMap":1048},[1053,8824,8825],{"class":1055,"line":1056},[1053,8826,8827],{"class":1059},"# shared/monitoring.py\n",[1053,8829,8830,8832],{"class":1055,"line":1063},[1053,8831,1770],{"class":1769},[1053,8833,8834],{"class":1509}," logging\n",[1053,8836,8837,8839],{"class":1055,"line":1080},[1053,8838,1770],{"class":1769},[1053,8840,8841],{"class":1509}," time\n",[1053,8843,8844,8846,8848,8850,8853,8855,8858,8860],{"class":1055,"line":1086},[1053,8845,1778],{"class":1769},[1053,8847,1406],{"class":1509},[1053,8849,1688],{"class":1494},[1053,8851,8852],{"class":1509},"utils",[1053,8854,1688],{"class":1494},[1053,8856,8857],{"class":1509},"deprecation ",[1053,8859,1770],{"class":1769},[1053,8861,8862],{"class":1509}," MiddlewareMixin\n",[1053,8864,8865,8867,8870,8872,8875,8877,8880,8882],{"class":1055,"line":1106},[1053,8866,1778],{"class":1769},[1053,8868,8869],{"class":1509}," prometheus_client ",[1053,8871,1770],{"class":1769},[1053,8873,8874],{"class":1509}," Counter",[1053,8876,1682],{"class":1494},[1053,8878,8879],{"class":1509}," Histogram",[1053,8881,1682],{"class":1494},[1053,8883,8884],{"class":1509}," generate_latest\n",[1053,8886,8887],{"class":1055,"line":1113},[1053,8888,1110],{"emptyLinePlaceholder":1109},[1053,8890,8891],{"class":1055,"line":1119},[1053,8892,8893],{"class":1059},"# Metrics\n",[1053,8895,8896,8899,8901,8903,8905,8907,8910,8912,8914,8916,8919,8921,8923,8925,8927,8930,8932,8934,8936,8939,8941,8943,8945,8947,8949],{"class":1055,"line":1134},[1053,8897,8898],{"class":1490},"REQUEST_COUNT",[1053,8900,1810],{"class":1494},[1053,8902,8874],{"class":1813},[1053,8904,1817],{"class":1494},[1053,8906,1862],{"class":1861},[1053,8908,8909],{"class":1070},"django_requests_total",[1053,8911,1862],{"class":1861},[1053,8913,1682],{"class":1494},[1053,8915,2317],{"class":1861},[1053,8917,8918],{"class":1070},"Total requests",[1053,8920,1862],{"class":1861},[1053,8922,1682],{"class":1494},[1053,8924,3512],{"class":1494},[1053,8926,1862],{"class":1861},[1053,8928,8929],{"class":1070},"method",[1053,8931,1862],{"class":1861},[1053,8933,1682],{"class":1494},[1053,8935,2317],{"class":1861},[1053,8937,8938],{"class":1070},"endpoint",[1053,8940,1862],{"class":1861},[1053,8942,1682],{"class":1494},[1053,8944,2317],{"class":1861},[1053,8946,8138],{"class":1070},[1053,8948,1862],{"class":1861},[1053,8950,8951],{"class":1494},"])\n",[1053,8953,8954,8957,8959,8961,8963,8965,8968,8970,8972,8974,8977,8979],{"class":1055,"line":1140},[1053,8955,8956],{"class":1490},"REQUEST_LATENCY",[1053,8958,1810],{"class":1494},[1053,8960,8879],{"class":1813},[1053,8962,1817],{"class":1494},[1053,8964,1862],{"class":1861},[1053,8966,8967],{"class":1070},"django_request_duration_seconds",[1053,8969,1862],{"class":1861},[1053,8971,1682],{"class":1494},[1053,8973,2317],{"class":1861},[1053,8975,8976],{"class":1070},"Request latency",[1053,8978,1862],{"class":1861},[1053,8980,1869],{"class":1494},[1053,8982,8983],{"class":1055,"line":1145},[1053,8984,1110],{"emptyLinePlaceholder":1109},[1053,8986,8987,8989,8993,8995,8998],{"class":1055,"line":1151},[1053,8988,3343],{"class":3176},[1053,8990,8992],{"class":8991},"sD-vU"," MetricsMiddleware",[1053,8994,1817],{"class":1494},[1053,8996,8997],{"class":1066},"MiddlewareMixin",[1053,8999,8110],{"class":1494},[1053,9001,9002,9005,9008,9010,9014,9016,9019],{"class":1055,"line":1163},[1053,9003,9004],{"class":3176},"    def",[1053,9006,9007],{"class":5293}," process_request",[1053,9009,1817],{"class":1494},[1053,9011,9013],{"class":9012},"sRjD_","self",[1053,9015,1682],{"class":1494},[1053,9017,9018],{"class":8106}," request",[1053,9020,8110],{"class":1494},[1053,9022,9023,9026,9028,9031,9033,9036,9038,9041],{"class":1055,"line":1168},[1053,9024,9025],{"class":1509},"        request",[1053,9027,1688],{"class":1494},[1053,9029,9030],{"class":1691},"start_time",[1053,9032,1810],{"class":1494},[1053,9034,9035],{"class":1509}," time",[1053,9037,1688],{"class":1494},[1053,9039,9040],{"class":1813},"time",[1053,9042,8636],{"class":1494},[1053,9044,9045],{"class":1055,"line":1181},[1053,9046,6176],{"class":1509},[1053,9048,9049,9051,9054,9056,9058,9060,9062,9064,9067],{"class":1055,"line":1186},[1053,9050,9004],{"class":3176},[1053,9052,9053],{"class":5293}," process_response",[1053,9055,1817],{"class":1494},[1053,9057,9013],{"class":9012},[1053,9059,1682],{"class":1494},[1053,9061,9018],{"class":8106},[1053,9063,1682],{"class":1494},[1053,9065,9066],{"class":8106}," response",[1053,9068,8110],{"class":1494},[1053,9070,9071,9073,9076,9078,9080,9082,9084,9086,9088],{"class":1055,"line":1192},[1053,9072,6440],{"class":1769},[1053,9074,9075],{"class":1235}," hasattr",[1053,9077,1817],{"class":1494},[1053,9079,8107],{"class":1813},[1053,9081,1682],{"class":1494},[1053,9083,2317],{"class":1861},[1053,9085,9030],{"class":1070},[1053,9087,1862],{"class":1861},[1053,9089,8110],{"class":1494},[1053,9091,9092,9095,9097,9099,9101,9103,9105,9108,9110,9112],{"class":1055,"line":1995},[1053,9093,9094],{"class":1509},"            duration ",[1053,9096,1495],{"class":1494},[1053,9098,9035],{"class":1509},[1053,9100,1688],{"class":1494},[1053,9102,9040],{"class":1813},[1053,9104,8239],{"class":1494},[1053,9106,9107],{"class":1422}," -",[1053,9109,9018],{"class":1509},[1053,9111,1688],{"class":1494},[1053,9113,9114],{"class":1691},"start_time\n",[1053,9116,9117,9120,9122,9125,9127,9130],{"class":1055,"line":2007},[1053,9118,9119],{"class":1490},"            REQUEST_LATENCY",[1053,9121,1688],{"class":1494},[1053,9123,9124],{"class":1813},"observe",[1053,9126,1817],{"class":1494},[1053,9128,9129],{"class":1813},"duration",[1053,9131,1869],{"class":1494},[1053,9133,9134,9137,9139,9142],{"class":1055,"line":2019},[1053,9135,9136],{"class":1490},"            REQUEST_COUNT",[1053,9138,1688],{"class":1494},[1053,9140,9141],{"class":1813},"labels",[1053,9143,9144],{"class":1494},"(\n",[1053,9146,9147,9150,9152,9154,9156,9158],{"class":1055,"line":2031},[1053,9148,9149],{"class":1890},"                method",[1053,9151,1495],{"class":1494},[1053,9153,8107],{"class":1813},[1053,9155,1688],{"class":1494},[1053,9157,8929],{"class":1691},[1053,9159,1981],{"class":1494},[1053,9161,9162,9165,9167,9169,9171,9174],{"class":1055,"line":2043},[1053,9163,9164],{"class":1890},"                endpoint",[1053,9166,1495],{"class":1494},[1053,9168,8107],{"class":1813},[1053,9170,1688],{"class":1494},[1053,9172,9173],{"class":1691},"path",[1053,9175,1981],{"class":1494},[1053,9177,9178,9181,9183,9186,9188],{"class":1055,"line":2049},[1053,9179,9180],{"class":1890},"                status",[1053,9182,1495],{"class":1494},[1053,9184,9185],{"class":1813},"response",[1053,9187,1688],{"class":1494},[1053,9189,9190],{"class":1691},"status_code\n",[1053,9192,9193,9196,9199],{"class":1055,"line":2054},[1053,9194,9195],{"class":1494},"            ).",[1053,9197,9198],{"class":1813},"inc",[1053,9200,8636],{"class":1494},[1053,9202,9203],{"class":1055,"line":2064},[1053,9204,7092],{"class":1509},[1053,9206,9207,9210],{"class":1055,"line":2076},[1053,9208,9209],{"class":1769},"        return",[1053,9211,9212],{"class":1509}," response\n",[1053,9214,9215],{"class":1055,"line":2088},[1053,9216,1110],{"emptyLinePlaceholder":1109},[1053,9218,9219,9221,9224,9226,9228],{"class":1055,"line":2100},[1053,9220,8098],{"class":3176},[1053,9222,9223],{"class":5293}," metrics_view",[1053,9225,1817],{"class":1494},[1053,9227,8107],{"class":8106},[1053,9229,8110],{"class":1494},[1053,9231,9232,9234,9237],{"class":1055,"line":2105},[1053,9233,8116],{"class":8115},[1053,9235,9236],{"class":6904},"Prometheus metrics endpoint",[1053,9238,8122],{"class":8115},[1053,9240,9241,9244,9246,9248,9250,9252],{"class":1055,"line":2110},[1053,9242,9243],{"class":1769},"    from",[1053,9245,1406],{"class":1509},[1053,9247,1688],{"class":1494},[1053,9249,8017],{"class":1509},[1053,9251,1770],{"class":1769},[1053,9253,9254],{"class":1509}," HttpResponse\n",[1053,9256,9257,9259,9262,9264,9267,9270,9273,9275,9277,9280,9282],{"class":1055,"line":2120},[1053,9258,8793],{"class":1769},[1053,9260,9261],{"class":1813}," HttpResponse",[1053,9263,1817],{"class":1494},[1053,9265,9266],{"class":1813},"generate_latest",[1053,9268,9269],{"class":1494},"(),",[1053,9271,9272],{"class":1890}," content_type",[1053,9274,1495],{"class":1494},[1053,9276,1862],{"class":1861},[1053,9278,9279],{"class":1070},"text/plain",[1053,9281,1862],{"class":1861},[1053,9283,1869],{"class":1494},[1030,9285,9287],{"id":9286},"development-workflow","Development Workflow",[1035,9289,9291],{"id":9290},"_1-daily-development-commands","1. Daily Development Commands",[1043,9293,9295],{"className":1045,"code":9294,"language":1047,"meta":1048,"style":1048},"# Start development environment\ndocker-compose up -d\n\n# View logs\ndocker-compose logs -f user-service\n\n# Run migrations\ndocker-compose exec user-service python manage.py migrate\n\n# Create superuser\ndocker-compose exec user-service python manage.py createsuperuser\n\n# Run tests\ndocker-compose exec user-service python manage.py test\n\n# Access service shell\ndocker-compose exec user-service python manage.py shell\n\n# Stop environment\ndocker-compose down\n",[1050,9296,9297,9302,9311,9315,9320,9330,9334,9339,9354,9358,9363,9378,9382,9387,9401,9405,9410,9425,9429,9434],{"__ignoreMap":1048},[1053,9298,9299],{"class":1055,"line":1056},[1053,9300,9301],{"class":1059},"# Start development environment\n",[1053,9303,9304,9307,9309],{"class":1055,"line":1063},[1053,9305,9306],{"class":1066},"docker-compose",[1053,9308,6476],{"class":1070},[1053,9310,6479],{"class":1254},[1053,9312,9313],{"class":1055,"line":1080},[1053,9314,1110],{"emptyLinePlaceholder":1109},[1053,9316,9317],{"class":1055,"line":1086},[1053,9318,9319],{"class":1059},"# View logs\n",[1053,9321,9322,9324,9326,9328],{"class":1055,"line":1106},[1053,9323,9306],{"class":1066},[1053,9325,6723],{"class":1070},[1053,9327,6247],{"class":1254},[1053,9329,5205],{"class":1070},[1053,9331,9332],{"class":1055,"line":1113},[1053,9333,1110],{"emptyLinePlaceholder":1109},[1053,9335,9336],{"class":1055,"line":1119},[1053,9337,9338],{"class":1059},"# Run migrations\n",[1053,9340,9341,9343,9345,9348,9350,9352],{"class":1055,"line":1134},[1053,9342,9306],{"class":1066},[1053,9344,6808],{"class":1070},[1053,9346,9347],{"class":1070}," user-service",[1053,9349,6878],{"class":1070},[1053,9351,1464],{"class":1070},[1053,9353,6315],{"class":1070},[1053,9355,9356],{"class":1055,"line":1140},[1053,9357,1110],{"emptyLinePlaceholder":1109},[1053,9359,9360],{"class":1055,"line":1145},[1053,9361,9362],{"class":1059},"# Create superuser\n",[1053,9364,9365,9367,9369,9371,9373,9375],{"class":1055,"line":1151},[1053,9366,9306],{"class":1066},[1053,9368,6808],{"class":1070},[1053,9370,9347],{"class":1070},[1053,9372,6878],{"class":1070},[1053,9374,1464],{"class":1070},[1053,9376,9377],{"class":1070}," createsuperuser\n",[1053,9379,9380],{"class":1055,"line":1163},[1053,9381,1110],{"emptyLinePlaceholder":1109},[1053,9383,9384],{"class":1055,"line":1168},[1053,9385,9386],{"class":1059},"# Run tests\n",[1053,9388,9389,9391,9393,9395,9397,9399],{"class":1055,"line":1181},[1053,9390,9306],{"class":1066},[1053,9392,6808],{"class":1070},[1053,9394,9347],{"class":1070},[1053,9396,6878],{"class":1070},[1053,9398,1464],{"class":1070},[1053,9400,7141],{"class":1070},[1053,9402,9403],{"class":1055,"line":1186},[1053,9404,1110],{"emptyLinePlaceholder":1109},[1053,9406,9407],{"class":1055,"line":1192},[1053,9408,9409],{"class":1059},"# Access service shell\n",[1053,9411,9412,9414,9416,9418,9420,9422],{"class":1055,"line":1995},[1053,9413,9306],{"class":1066},[1053,9415,6808],{"class":1070},[1053,9417,9347],{"class":1070},[1053,9419,6878],{"class":1070},[1053,9421,1464],{"class":1070},[1053,9423,9424],{"class":1070}," shell\n",[1053,9426,9427],{"class":1055,"line":2007},[1053,9428,1110],{"emptyLinePlaceholder":1109},[1053,9430,9431],{"class":1055,"line":2019},[1053,9432,9433],{"class":1059},"# Stop environment\n",[1053,9435,9436,9438],{"class":1055,"line":2031},[1053,9437,9306],{"class":1066},[1053,9439,6568],{"class":1070},[1035,9441,9443],{"id":9442},"_2-service-development-cycle","2. Service Development Cycle",[1043,9445,9447],{"className":1045,"code":9446,"language":1047,"meta":1048,"style":1048},"# 1. Make code changes\n# 2. Restart specific service\ndocker-compose restart user-service\n\n# 3. Check logs\ndocker-compose logs -f user-service\n\n# 4. Run tests\ndocker-compose exec user-service python manage.py test\n\n# 5. Test API endpoints\nhttp GET localhost:8000/api/v1/users/ Authorization:\"Token your-token\"\n",[1050,9448,9449,9454,9459,9467,9471,9476,9486,9490,9495,9509,9513,9518],{"__ignoreMap":1048},[1053,9450,9451],{"class":1055,"line":1056},[1053,9452,9453],{"class":1059},"# 1. Make code changes\n",[1053,9455,9456],{"class":1055,"line":1063},[1053,9457,9458],{"class":1059},"# 2. Restart specific service\n",[1053,9460,9461,9463,9465],{"class":1055,"line":1080},[1053,9462,9306],{"class":1066},[1053,9464,6677],{"class":1070},[1053,9466,5205],{"class":1070},[1053,9468,9469],{"class":1055,"line":1086},[1053,9470,1110],{"emptyLinePlaceholder":1109},[1053,9472,9473],{"class":1055,"line":1106},[1053,9474,9475],{"class":1059},"# 3. Check logs\n",[1053,9477,9478,9480,9482,9484],{"class":1055,"line":1113},[1053,9479,9306],{"class":1066},[1053,9481,6723],{"class":1070},[1053,9483,6247],{"class":1254},[1053,9485,5205],{"class":1070},[1053,9487,9488],{"class":1055,"line":1119},[1053,9489,1110],{"emptyLinePlaceholder":1109},[1053,9491,9492],{"class":1055,"line":1134},[1053,9493,9494],{"class":1059},"# 4. Run tests\n",[1053,9496,9497,9499,9501,9503,9505,9507],{"class":1055,"line":1140},[1053,9498,9306],{"class":1066},[1053,9500,6808],{"class":1070},[1053,9502,9347],{"class":1070},[1053,9504,6878],{"class":1070},[1053,9506,1464],{"class":1070},[1053,9508,7141],{"class":1070},[1053,9510,9511],{"class":1055,"line":1145},[1053,9512,1110],{"emptyLinePlaceholder":1109},[1053,9514,9515],{"class":1055,"line":1151},[1053,9516,9517],{"class":1059},"# 5. Test API endpoints\n",[1053,9519,9520,9522,9525,9528,9531,9533,9536],{"class":1055,"line":1163},[1053,9521,1720],{"class":1066},[1053,9523,9524],{"class":1070}," GET",[1053,9526,9527],{"class":1070}," localhost:8000/api/v1/users/",[1053,9529,9530],{"class":1070}," Authorization:",[1053,9532,4160],{"class":1861},[1053,9534,9535],{"class":1070},"Token your-token",[1053,9537,4141],{"class":1861},[1030,9539,9541],{"id":9540},"summary","Summary",[1026,9543,9544],{},"A well-configured development and runtime environment is essential for microservices success. Key components include:",[9546,9547,9548,9552,9555,9558,9561,9564,9567],"ul",{},[9549,9550,9551],"li",{},"Containerized services with Docker",[9549,9553,9554],{},"Infrastructure services (PostgreSQL, Redis, RabbitMQ)",[9549,9556,9557],{},"API Gateway for routing",[9549,9559,9560],{},"Service discovery with Consul",[9549,9562,9563],{},"Comprehensive health checks",[9549,9565,9566],{},"Monitoring and metrics",[9549,9568,9569],{},"Automated setup scripts",[1026,9571,9572],{},"This foundation enables efficient development, testing, and deployment of Django microservices. In the next section, we'll explore cloud-native data processing with MongoDB.",[3202,9574,9575],{},"html pre.shiki code .s9Tkl, html code.shiki .s9Tkl{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#A0ADA0;--shiki-default-font-style:inherit;--shiki-dark:#758575DD;--shiki-dark-font-style:inherit}html pre.shiki code .sYn-s, html code.shiki .sYn-s{--shiki-light:#E2931D;--shiki-default:#59873A;--shiki-dark:#80A665}html pre.shiki code .sTbE_, html code.shiki .sTbE_{--shiki-light:#91B859;--shiki-default:#B56959;--shiki-dark:#C98A7D}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sJdAF, html code.shiki .sJdAF{--shiki-light:#6182B8;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .sz9Cv, html code.shiki .sz9Cv{--shiki-light:#91B859;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sVsLi, html code.shiki .sVsLi{--shiki-light:#39ADB5;--shiki-default:#AB5959;--shiki-dark:#CB7676}html pre.shiki code .se3Ec, html code.shiki .se3Ec{--shiki-light:#90A4AE;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .soVBu, html code.shiki .soVBu{--shiki-light:#39ADB5;--shiki-default:#999999;--shiki-dark:#666666}html pre.shiki code .s8XtY, html code.shiki .s8XtY{--shiki-light:#39ADB5;--shiki-default:#1E754F;--shiki-dark:#4D9375}html pre.shiki code .sftqT, html code.shiki .sftqT{--shiki-light:#90A4AE;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .s7CZa, html code.shiki .s7CZa{--shiki-light:#F76D47;--shiki-default:#2F798A;--shiki-dark:#4C9A91}html pre.shiki code .sBPpx, html code.shiki .sBPpx{--shiki-light:#E53935;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .siDh9, html code.shiki .siDh9{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#1E754F;--shiki-default-font-style:inherit;--shiki-dark:#4D9375;--shiki-dark-font-style:inherit}html pre.shiki code .siWMO, html code.shiki .siWMO{--shiki-light:#6182B8;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .s131V, html code.shiki .s131V{--shiki-light:#90A4AE;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .sbYkP, html code.shiki .sbYkP{--shiki-light:#39ADB5;--shiki-default:#B5695977;--shiki-dark:#C98A7D77}html pre.shiki code .sqOPj, html code.shiki .sqOPj{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#B07D48;--shiki-default-font-style:inherit;--shiki-dark:#BD976A;--shiki-dark-font-style:inherit}html pre.shiki code .sa2tF, html code.shiki .sa2tF{--shiki-light:#E2931D;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .s3h35, html code.shiki .s3h35{--shiki-light:#F76D47;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .s5Kfy, html code.shiki .s5Kfy{--shiki-light:#9C3EDA;--shiki-default:#AB5959;--shiki-dark:#CB7676}html pre.shiki code .scgAs, html code.shiki .scgAs{--shiki-light:#F76D47;--shiki-default:#1E754F;--shiki-dark:#4D9375}html pre.shiki code .suXOh, html code.shiki .suXOh{--shiki-light:#E53935;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .sljsM, html code.shiki .sljsM{--shiki-light:#6182B8;--shiki-default:#59873A;--shiki-dark:#80A665}html pre.shiki code .sq3J1, html code.shiki .sq3J1{--shiki-light:#FF5370;--shiki-default:#1E754F;--shiki-dark:#4D9375}html pre.shiki code .sSC40, html code.shiki .sSC40{--shiki-light:#90A4AE;--shiki-default:#B07D48;--shiki-dark:#BD976A}html pre.shiki code .su_V2, html code.shiki .su_V2{--shiki-light:#90A4AE;--shiki-default:#B56959;--shiki-dark:#C98A7D}html pre.shiki code .sVyVU, html code.shiki .sVyVU{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#B56959;--shiki-default-font-style:inherit;--shiki-dark:#C98A7D;--shiki-dark-font-style:inherit}html pre.shiki code .sCyAa, html code.shiki .sCyAa{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#393A34;--shiki-default-font-style:inherit;--shiki-dark:#DBD7CAEE;--shiki-dark-font-style:inherit}html pre.shiki code .sm7ve, html code.shiki .sm7ve{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#B5695977;--shiki-default-font-style:inherit;--shiki-dark:#C98A7D77;--shiki-dark-font-style:inherit}html pre.shiki code .sFGJz, html code.shiki .sFGJz{--shiki-light:#E53935;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sD-vU, html code.shiki .sD-vU{--shiki-light:#E2931D;--shiki-default:#2E8F82;--shiki-dark:#5DA994}html pre.shiki code .sRjD_, html code.shiki .sRjD_{--shiki-light:#E53935;--shiki-light-font-style:italic;--shiki-default:#393A34;--shiki-default-font-style:inherit;--shiki-dark:#DBD7CAEE;--shiki-dark-font-style:inherit}",{"title":1048,"searchDepth":1056,"depth":1063,"links":9577},[9578,9584,9590,9595,9601,9605],{"id":1032,"depth":1063,"text":1033,"children":9579},[9580,9581,9582,9583],{"id":1037,"depth":1080,"text":1038},{"id":1208,"depth":1080,"text":1209},{"id":1335,"depth":1080,"text":1336},{"id":1473,"depth":1080,"text":1474},{"id":3721,"depth":1063,"text":3722,"children":9585},[9586,9587,9588,9589],{"id":3725,"depth":1080,"text":3726},{"id":4001,"depth":1080,"text":4002},{"id":5269,"depth":1080,"text":5270},{"id":5518,"depth":1080,"text":5519},{"id":6020,"depth":1063,"text":6021,"children":9591},[9592,9593,9594],{"id":6024,"depth":1080,"text":6025},{"id":6369,"depth":1080,"text":6370},{"id":6929,"depth":1080,"text":6930},{"id":7186,"depth":1063,"text":7187,"children":9596},[9597,9598,9599,9600],{"id":7190,"depth":1080,"text":7191},{"id":7874,"depth":1080,"text":7875},{"id":7995,"depth":1080,"text":7996},{"id":8816,"depth":1080,"text":8817},{"id":9286,"depth":1063,"text":9287,"children":9602},[9603,9604],{"id":9290,"depth":1080,"text":9291},{"id":9442,"depth":1080,"text":9443},{"id":9540,"depth":1063,"text":9541},"md",null,{},{"title":889,"description":1028},"7BbwM3ipI_UZ1hFQV7XwyhOLAyTMiuQQRsX6ZWRSe0Y",[9612,9614],{"title":885,"path":886,"stem":887,"description":9613,"children":-1},"Django, traditionally known for building monolithic web applications, can be effectively adapted for microservices architecture. In this section, we'll explore Django's native components that support microservices development and the external tools that complement Django in a distributed environment.",{"title":893,"path":894,"stem":895,"description":9615,"children":-1},"MongoDB is an excellent choice for microservices due to its flexible schema, horizontal scaling capabilities, and cloud-native features. This section explores how to integrate MongoDB with Django microservices for efficient data processing and storage.",1772474962712]