[{"data":1,"prerenderedAt":8202},["ShallowReactive",2],{"navigation":3,"/logging-in-django":1016,"/logging-in-django-surround":8197},[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":851,"body":1018,"description":1028,"extension":8192,"links":8193,"meta":8194,"navigation":1660,"path":852,"seo":8195,"stem":853,"__hash__":8196},"docs/23.logging-in-django/01.index.md",{"type":1019,"value":1020,"toc":8166},"minimark",[1021,1025,1029,1034,1037,1042,1061,1065,1068,1109,1113,1117,1633,1637,3021,3025,3029,3392,3396,4423,4427,5246,5250,5254,5811,5815,6350,6354,6927,6931,6935,7380,7384,7679,7683,8108,8111,8160,8163],[1022,1023,851],"h1",{"id":1024},"logging-in-django",[1026,1027,1028],"p",{},"Logging is essential for monitoring, debugging, and maintaining Django applications. Django's logging framework, built on Python's logging module, provides flexible and powerful tools for capturing and managing application logs across development and production environments.",[1030,1031,1033],"h2",{"id":1032},"understanding-django-logging","Understanding Django Logging",[1026,1035,1036],{},"Django uses Python's standard logging module with pre-configured loggers for different components. Understanding the logging architecture helps you effectively capture and manage application events.",[1038,1039,1041],"h3",{"id":1040},"logging-components","Logging Components",[1026,1043,1044,1048,1049,1052,1053,1056,1057,1060],{},[1045,1046,1047],"strong",{},"Loggers",": Entry points for log messages\n",[1045,1050,1051],{},"Handlers",": Determine where log messages go (file, console, email, etc.)\n",[1045,1054,1055],{},"Filters",": Provide fine-grained control over which log records are processed\n",[1045,1058,1059],{},"Formatters",": Specify the layout of log messages",[1038,1062,1064],{"id":1063},"default-django-loggers","Default Django Loggers",[1026,1066,1067],{},"Django provides several built-in loggers:",[1069,1070,1071,1079,1085,1091,1097,1103],"ul",{},[1072,1073,1074,1078],"li",{},[1075,1076,1077],"code",{},"django",": Root logger for all Django messages",[1072,1080,1081,1084],{},[1075,1082,1083],{},"django.request",": HTTP request/response cycle",[1072,1086,1087,1090],{},[1075,1088,1089],{},"django.server",": Development server messages",[1072,1092,1093,1096],{},[1075,1094,1095],{},"django.template",": Template rendering issues",[1072,1098,1099,1102],{},[1075,1100,1101],{},"django.db.backends",": Database query execution",[1072,1104,1105,1108],{},[1075,1106,1107],{},"django.security",": Security-related messages",[1030,1110,1112],{"id":1111},"basic-logging-configuration","Basic Logging Configuration",[1038,1114,1116],{"id":1115},"simple-configuration","Simple Configuration",[1118,1119,1124],"pre",{"className":1120,"code":1121,"language":1122,"meta":1123,"style":1123},"language-python shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","# settings.py\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        'console': {\n            'class': 'logging.StreamHandler',\n            'formatter': 'simple',\n        },\n        'file': {\n            'class': 'logging.FileHandler',\n            'filename': 'django.log',\n            'formatter': 'verbose',\n        },\n    },\n    'loggers': {\n        'django': {\n            'handlers': ['console', 'file'],\n            'level': 'INFO',\n            'propagate': True,\n        },\n    },\n}\n","python","",[1075,1125,1126,1135,1149,1173,1191,1205,1220,1270,1291,1297,1311,1332,1351,1356,1362,1376,1390,1411,1431,1436,1450,1470,1491,1510,1515,1520,1534,1547,1579,1600,1617,1622,1627],{"__ignoreMap":1123},[1127,1128,1131],"span",{"class":1129,"line":1130},"line",1,[1127,1132,1134],{"class":1133},"s9Tkl","# settings.py\n",[1127,1136,1138,1142,1146],{"class":1129,"line":1137},2,[1127,1139,1141],{"class":1140},"se3Ec","LOGGING",[1127,1143,1145],{"class":1144},"soVBu"," =",[1127,1147,1148],{"class":1144}," {\n",[1127,1150,1152,1156,1160,1163,1166,1170],{"class":1129,"line":1151},3,[1127,1153,1155],{"class":1154},"sbYkP","    '",[1127,1157,1159],{"class":1158},"sTbE_","version",[1127,1161,1162],{"class":1154},"'",[1127,1164,1165],{"class":1144},":",[1127,1167,1169],{"class":1168},"s7CZa"," 1",[1127,1171,1172],{"class":1144},",\n",[1127,1174,1176,1178,1181,1183,1185,1189],{"class":1129,"line":1175},4,[1127,1177,1155],{"class":1154},[1127,1179,1180],{"class":1158},"disable_existing_loggers",[1127,1182,1162],{"class":1154},[1127,1184,1165],{"class":1144},[1127,1186,1188],{"class":1187},"s8XtY"," False",[1127,1190,1172],{"class":1144},[1127,1192,1194,1196,1199,1201,1203],{"class":1129,"line":1193},5,[1127,1195,1155],{"class":1154},[1127,1197,1198],{"class":1158},"formatters",[1127,1200,1162],{"class":1154},[1127,1202,1165],{"class":1144},[1127,1204,1148],{"class":1144},[1127,1206,1208,1211,1214,1216,1218],{"class":1129,"line":1207},6,[1127,1209,1210],{"class":1154},"        '",[1127,1212,1213],{"class":1158},"verbose",[1127,1215,1162],{"class":1154},[1127,1217,1165],{"class":1144},[1127,1219,1148],{"class":1144},[1127,1221,1223,1226,1229,1231,1233,1236,1240,1243,1246,1249,1253,1256,1259,1261,1263,1266,1268],{"class":1129,"line":1222},7,[1127,1224,1225],{"class":1154},"            '",[1127,1227,1228],{"class":1158},"format",[1127,1230,1162],{"class":1154},[1127,1232,1165],{"class":1144},[1127,1234,1235],{"class":1154}," '",[1127,1237,1239],{"class":1238},"s3h35","{levelname}",[1127,1241,1242],{"class":1238}," {asctime}",[1127,1244,1245],{"class":1238}," {module}",[1127,1247,1248],{"class":1238}," {process",[1127,1250,1252],{"class":1251},"s5Kfy",":d",[1127,1254,1255],{"class":1238},"}",[1127,1257,1258],{"class":1238}," {thread",[1127,1260,1252],{"class":1251},[1127,1262,1255],{"class":1238},[1127,1264,1265],{"class":1238}," {message}",[1127,1267,1162],{"class":1154},[1127,1269,1172],{"class":1144},[1127,1271,1273,1275,1278,1280,1282,1284,1287,1289],{"class":1129,"line":1272},8,[1127,1274,1225],{"class":1154},[1127,1276,1277],{"class":1158},"style",[1127,1279,1162],{"class":1154},[1127,1281,1165],{"class":1144},[1127,1283,1235],{"class":1154},[1127,1285,1286],{"class":1158},"{",[1127,1288,1162],{"class":1154},[1127,1290,1172],{"class":1144},[1127,1292,1294],{"class":1129,"line":1293},9,[1127,1295,1296],{"class":1144},"        },\n",[1127,1298,1300,1302,1305,1307,1309],{"class":1129,"line":1299},10,[1127,1301,1210],{"class":1154},[1127,1303,1304],{"class":1158},"simple",[1127,1306,1162],{"class":1154},[1127,1308,1165],{"class":1144},[1127,1310,1148],{"class":1144},[1127,1312,1314,1316,1318,1320,1322,1324,1326,1328,1330],{"class":1129,"line":1313},11,[1127,1315,1225],{"class":1154},[1127,1317,1228],{"class":1158},[1127,1319,1162],{"class":1154},[1127,1321,1165],{"class":1144},[1127,1323,1235],{"class":1154},[1127,1325,1239],{"class":1238},[1127,1327,1265],{"class":1238},[1127,1329,1162],{"class":1154},[1127,1331,1172],{"class":1144},[1127,1333,1335,1337,1339,1341,1343,1345,1347,1349],{"class":1129,"line":1334},12,[1127,1336,1225],{"class":1154},[1127,1338,1277],{"class":1158},[1127,1340,1162],{"class":1154},[1127,1342,1165],{"class":1144},[1127,1344,1235],{"class":1154},[1127,1346,1286],{"class":1158},[1127,1348,1162],{"class":1154},[1127,1350,1172],{"class":1144},[1127,1352,1354],{"class":1129,"line":1353},13,[1127,1355,1296],{"class":1144},[1127,1357,1359],{"class":1129,"line":1358},14,[1127,1360,1361],{"class":1144},"    },\n",[1127,1363,1365,1367,1370,1372,1374],{"class":1129,"line":1364},15,[1127,1366,1155],{"class":1154},[1127,1368,1369],{"class":1158},"handlers",[1127,1371,1162],{"class":1154},[1127,1373,1165],{"class":1144},[1127,1375,1148],{"class":1144},[1127,1377,1379,1381,1384,1386,1388],{"class":1129,"line":1378},16,[1127,1380,1210],{"class":1154},[1127,1382,1383],{"class":1158},"console",[1127,1385,1162],{"class":1154},[1127,1387,1165],{"class":1144},[1127,1389,1148],{"class":1144},[1127,1391,1393,1395,1398,1400,1402,1404,1407,1409],{"class":1129,"line":1392},17,[1127,1394,1225],{"class":1154},[1127,1396,1397],{"class":1158},"class",[1127,1399,1162],{"class":1154},[1127,1401,1165],{"class":1144},[1127,1403,1235],{"class":1154},[1127,1405,1406],{"class":1158},"logging.StreamHandler",[1127,1408,1162],{"class":1154},[1127,1410,1172],{"class":1144},[1127,1412,1414,1416,1419,1421,1423,1425,1427,1429],{"class":1129,"line":1413},18,[1127,1415,1225],{"class":1154},[1127,1417,1418],{"class":1158},"formatter",[1127,1420,1162],{"class":1154},[1127,1422,1165],{"class":1144},[1127,1424,1235],{"class":1154},[1127,1426,1304],{"class":1158},[1127,1428,1162],{"class":1154},[1127,1430,1172],{"class":1144},[1127,1432,1434],{"class":1129,"line":1433},19,[1127,1435,1296],{"class":1144},[1127,1437,1439,1441,1444,1446,1448],{"class":1129,"line":1438},20,[1127,1440,1210],{"class":1154},[1127,1442,1443],{"class":1158},"file",[1127,1445,1162],{"class":1154},[1127,1447,1165],{"class":1144},[1127,1449,1148],{"class":1144},[1127,1451,1453,1455,1457,1459,1461,1463,1466,1468],{"class":1129,"line":1452},21,[1127,1454,1225],{"class":1154},[1127,1456,1397],{"class":1158},[1127,1458,1162],{"class":1154},[1127,1460,1165],{"class":1144},[1127,1462,1235],{"class":1154},[1127,1464,1465],{"class":1158},"logging.FileHandler",[1127,1467,1162],{"class":1154},[1127,1469,1172],{"class":1144},[1127,1471,1473,1475,1478,1480,1482,1484,1487,1489],{"class":1129,"line":1472},22,[1127,1474,1225],{"class":1154},[1127,1476,1477],{"class":1158},"filename",[1127,1479,1162],{"class":1154},[1127,1481,1165],{"class":1144},[1127,1483,1235],{"class":1154},[1127,1485,1486],{"class":1158},"django.log",[1127,1488,1162],{"class":1154},[1127,1490,1172],{"class":1144},[1127,1492,1494,1496,1498,1500,1502,1504,1506,1508],{"class":1129,"line":1493},23,[1127,1495,1225],{"class":1154},[1127,1497,1418],{"class":1158},[1127,1499,1162],{"class":1154},[1127,1501,1165],{"class":1144},[1127,1503,1235],{"class":1154},[1127,1505,1213],{"class":1158},[1127,1507,1162],{"class":1154},[1127,1509,1172],{"class":1144},[1127,1511,1513],{"class":1129,"line":1512},24,[1127,1514,1296],{"class":1144},[1127,1516,1518],{"class":1129,"line":1517},25,[1127,1519,1361],{"class":1144},[1127,1521,1523,1525,1528,1530,1532],{"class":1129,"line":1522},26,[1127,1524,1155],{"class":1154},[1127,1526,1527],{"class":1158},"loggers",[1127,1529,1162],{"class":1154},[1127,1531,1165],{"class":1144},[1127,1533,1148],{"class":1144},[1127,1535,1537,1539,1541,1543,1545],{"class":1129,"line":1536},27,[1127,1538,1210],{"class":1154},[1127,1540,1077],{"class":1158},[1127,1542,1162],{"class":1154},[1127,1544,1165],{"class":1144},[1127,1546,1148],{"class":1144},[1127,1548,1550,1552,1554,1556,1558,1561,1563,1565,1567,1570,1572,1574,1576],{"class":1129,"line":1549},28,[1127,1551,1225],{"class":1154},[1127,1553,1369],{"class":1158},[1127,1555,1162],{"class":1154},[1127,1557,1165],{"class":1144},[1127,1559,1560],{"class":1144}," [",[1127,1562,1162],{"class":1154},[1127,1564,1383],{"class":1158},[1127,1566,1162],{"class":1154},[1127,1568,1569],{"class":1144},",",[1127,1571,1235],{"class":1154},[1127,1573,1443],{"class":1158},[1127,1575,1162],{"class":1154},[1127,1577,1578],{"class":1144},"],\n",[1127,1580,1582,1584,1587,1589,1591,1593,1596,1598],{"class":1129,"line":1581},29,[1127,1583,1225],{"class":1154},[1127,1585,1586],{"class":1158},"level",[1127,1588,1162],{"class":1154},[1127,1590,1165],{"class":1144},[1127,1592,1235],{"class":1154},[1127,1594,1595],{"class":1158},"INFO",[1127,1597,1162],{"class":1154},[1127,1599,1172],{"class":1144},[1127,1601,1603,1605,1608,1610,1612,1615],{"class":1129,"line":1602},30,[1127,1604,1225],{"class":1154},[1127,1606,1607],{"class":1158},"propagate",[1127,1609,1162],{"class":1154},[1127,1611,1165],{"class":1144},[1127,1613,1614],{"class":1187}," True",[1127,1616,1172],{"class":1144},[1127,1618,1620],{"class":1129,"line":1619},31,[1127,1621,1296],{"class":1144},[1127,1623,1625],{"class":1129,"line":1624},32,[1127,1626,1361],{"class":1144},[1127,1628,1630],{"class":1129,"line":1629},33,[1127,1631,1632],{"class":1144},"}\n",[1038,1634,1636],{"id":1635},"production-ready-configuration","Production-Ready Configuration",[1118,1638,1640],{"className":1120,"code":1639,"language":1122,"meta":1123,"style":1123},"# settings.py\nimport os\n\nLOGGING = {\n    'version': 1,\n    'disable_existing_loggers': False,\n    'formatters': {\n        'verbose': {\n            'format': '[{levelname}] {asctime} {name} {module}.{funcName}:{lineno} - {message}',\n            'style': '{',\n            'datefmt': '%Y-%m-%d %H:%M:%S',\n        },\n        'simple': {\n            'format': '[{levelname}] {message}',\n            'style': '{',\n        },\n        'json': {\n            '()': 'pythonjsonlogger.jsonlogger.JsonFormatter',\n            'format': '%(asctime)s %(name)s %(levelname)s %(message)s',\n        },\n    },\n    'filters': {\n        'require_debug_false': {\n            '()': 'django.utils.log.RequireDebugFalse',\n        },\n        'require_debug_true': {\n            '()': 'django.utils.log.RequireDebugTrue',\n        },\n    },\n    'handlers': {\n        'console': {\n            'level': 'INFO',\n            'filters': ['require_debug_true'],\n            'class': 'logging.StreamHandler',\n            'formatter': 'simple',\n        },\n        'file': {\n            'level': 'INFO',\n            'class': 'logging.handlers.RotatingFileHandler',\n            'filename': os.path.join(BASE_DIR, 'logs', 'django.log'),\n            'maxBytes': 1024 * 1024 * 15,  # 15MB\n            'backupCount': 10,\n            'formatter': 'verbose',\n        },\n        'error_file': {\n            'level': 'ERROR',\n            'class': 'logging.handlers.RotatingFileHandler',\n            'filename': os.path.join(BASE_DIR, 'logs', 'django_errors.log'),\n            'maxBytes': 1024 * 1024 * 15,  # 15MB\n            'backupCount': 10,\n            'formatter': 'verbose',\n        },\n        'mail_admins': {\n            'level': 'ERROR',\n            'filters': ['require_debug_false'],\n            'class': 'django.utils.log.AdminEmailHandler',\n            'include_html': True,\n        },\n    },\n    'loggers': {\n        'django': {\n            'handlers': ['console', 'file'],\n            'level': 'INFO',\n            'propagate': False,\n        },\n        'django.request': {\n            'handlers': ['error_file', 'mail_admins'],\n            'level': 'ERROR',\n            'propagate': False,\n        },\n        'django.db.backends': {\n            'handlers': ['console'],\n            'level': 'DEBUG' if DEBUG else 'INFO',\n            'propagate': False,\n        },\n        'myapp': {\n            'handlers': ['console', 'file', 'error_file'],\n            'level': 'DEBUG' if DEBUG else 'INFO',\n            'propagate': False,\n        },\n    },\n    'root': {\n        'handlers': ['console', 'file'],\n        'level': 'INFO',\n    },\n}\n",[1075,1641,1642,1646,1656,1662,1670,1684,1698,1710,1722,1771,1789,1815,1819,1831,1855,1873,1877,1890,1910,1938,1942,1946,1959,1972,1991,1995,2008,2027,2031,2035,2047,2059,2077,2097,2116,2135,2140,2153,2172,2192,2245,2276,2293,2312,2317,2331,2351,2370,2414,2439,2454,2473,2478,2492,2511,2532,2552,2568,2573,2578,2591,2604,2633,2652,2667,2672,2685,2714,2733,2748,2753,2766,2787,2822,2837,2842,2856,2893,2924,2939,2944,2949,2963,2992,3011,3016],{"__ignoreMap":1123},[1127,1643,1644],{"class":1129,"line":1130},[1127,1645,1134],{"class":1133},[1127,1647,1648,1652],{"class":1129,"line":1137},[1127,1649,1651],{"class":1650},"siDh9","import",[1127,1653,1655],{"class":1654},"sftqT"," os\n",[1127,1657,1658],{"class":1129,"line":1151},[1127,1659,1661],{"emptyLinePlaceholder":1660},true,"\n",[1127,1663,1664,1666,1668],{"class":1129,"line":1175},[1127,1665,1141],{"class":1140},[1127,1667,1145],{"class":1144},[1127,1669,1148],{"class":1144},[1127,1671,1672,1674,1676,1678,1680,1682],{"class":1129,"line":1193},[1127,1673,1155],{"class":1154},[1127,1675,1159],{"class":1158},[1127,1677,1162],{"class":1154},[1127,1679,1165],{"class":1144},[1127,1681,1169],{"class":1168},[1127,1683,1172],{"class":1144},[1127,1685,1686,1688,1690,1692,1694,1696],{"class":1129,"line":1207},[1127,1687,1155],{"class":1154},[1127,1689,1180],{"class":1158},[1127,1691,1162],{"class":1154},[1127,1693,1165],{"class":1144},[1127,1695,1188],{"class":1187},[1127,1697,1172],{"class":1144},[1127,1699,1700,1702,1704,1706,1708],{"class":1129,"line":1222},[1127,1701,1155],{"class":1154},[1127,1703,1198],{"class":1158},[1127,1705,1162],{"class":1154},[1127,1707,1165],{"class":1144},[1127,1709,1148],{"class":1144},[1127,1711,1712,1714,1716,1718,1720],{"class":1129,"line":1272},[1127,1713,1210],{"class":1154},[1127,1715,1213],{"class":1158},[1127,1717,1162],{"class":1154},[1127,1719,1165],{"class":1144},[1127,1721,1148],{"class":1144},[1127,1723,1724,1726,1728,1730,1732,1734,1737,1739,1742,1745,1748,1750,1753,1756,1758,1761,1764,1767,1769],{"class":1129,"line":1293},[1127,1725,1225],{"class":1154},[1127,1727,1228],{"class":1158},[1127,1729,1162],{"class":1154},[1127,1731,1165],{"class":1144},[1127,1733,1235],{"class":1154},[1127,1735,1736],{"class":1158},"[",[1127,1738,1239],{"class":1238},[1127,1740,1741],{"class":1158},"] ",[1127,1743,1744],{"class":1238},"{asctime}",[1127,1746,1747],{"class":1238}," {name}",[1127,1749,1245],{"class":1238},[1127,1751,1752],{"class":1158},".",[1127,1754,1755],{"class":1238},"{funcName}",[1127,1757,1165],{"class":1158},[1127,1759,1760],{"class":1238},"{lineno}",[1127,1762,1763],{"class":1158}," - ",[1127,1765,1766],{"class":1238},"{message}",[1127,1768,1162],{"class":1154},[1127,1770,1172],{"class":1144},[1127,1772,1773,1775,1777,1779,1781,1783,1785,1787],{"class":1129,"line":1299},[1127,1774,1225],{"class":1154},[1127,1776,1277],{"class":1158},[1127,1778,1162],{"class":1154},[1127,1780,1165],{"class":1144},[1127,1782,1235],{"class":1154},[1127,1784,1286],{"class":1158},[1127,1786,1162],{"class":1154},[1127,1788,1172],{"class":1144},[1127,1790,1791,1793,1796,1798,1800,1802,1805,1808,1811,1813],{"class":1129,"line":1313},[1127,1792,1225],{"class":1154},[1127,1794,1795],{"class":1158},"datefmt",[1127,1797,1162],{"class":1154},[1127,1799,1165],{"class":1144},[1127,1801,1235],{"class":1154},[1127,1803,1804],{"class":1158},"%Y-%m-",[1127,1806,1807],{"class":1238},"%d",[1127,1809,1810],{"class":1158}," %H:%M:%S",[1127,1812,1162],{"class":1154},[1127,1814,1172],{"class":1144},[1127,1816,1817],{"class":1129,"line":1334},[1127,1818,1296],{"class":1144},[1127,1820,1821,1823,1825,1827,1829],{"class":1129,"line":1353},[1127,1822,1210],{"class":1154},[1127,1824,1304],{"class":1158},[1127,1826,1162],{"class":1154},[1127,1828,1165],{"class":1144},[1127,1830,1148],{"class":1144},[1127,1832,1833,1835,1837,1839,1841,1843,1845,1847,1849,1851,1853],{"class":1129,"line":1358},[1127,1834,1225],{"class":1154},[1127,1836,1228],{"class":1158},[1127,1838,1162],{"class":1154},[1127,1840,1165],{"class":1144},[1127,1842,1235],{"class":1154},[1127,1844,1736],{"class":1158},[1127,1846,1239],{"class":1238},[1127,1848,1741],{"class":1158},[1127,1850,1766],{"class":1238},[1127,1852,1162],{"class":1154},[1127,1854,1172],{"class":1144},[1127,1856,1857,1859,1861,1863,1865,1867,1869,1871],{"class":1129,"line":1364},[1127,1858,1225],{"class":1154},[1127,1860,1277],{"class":1158},[1127,1862,1162],{"class":1154},[1127,1864,1165],{"class":1144},[1127,1866,1235],{"class":1154},[1127,1868,1286],{"class":1158},[1127,1870,1162],{"class":1154},[1127,1872,1172],{"class":1144},[1127,1874,1875],{"class":1129,"line":1378},[1127,1876,1296],{"class":1144},[1127,1878,1879,1881,1884,1886,1888],{"class":1129,"line":1392},[1127,1880,1210],{"class":1154},[1127,1882,1883],{"class":1158},"json",[1127,1885,1162],{"class":1154},[1127,1887,1165],{"class":1144},[1127,1889,1148],{"class":1144},[1127,1891,1892,1894,1897,1899,1901,1903,1906,1908],{"class":1129,"line":1413},[1127,1893,1225],{"class":1154},[1127,1895,1896],{"class":1158},"()",[1127,1898,1162],{"class":1154},[1127,1900,1165],{"class":1144},[1127,1902,1235],{"class":1154},[1127,1904,1905],{"class":1158},"pythonjsonlogger.jsonlogger.JsonFormatter",[1127,1907,1162],{"class":1154},[1127,1909,1172],{"class":1144},[1127,1911,1912,1914,1916,1918,1920,1922,1925,1928,1931,1934,1936],{"class":1129,"line":1433},[1127,1913,1225],{"class":1154},[1127,1915,1228],{"class":1158},[1127,1917,1162],{"class":1154},[1127,1919,1165],{"class":1144},[1127,1921,1235],{"class":1154},[1127,1923,1924],{"class":1238},"%(asctime)s",[1127,1926,1927],{"class":1238}," %(name)s",[1127,1929,1930],{"class":1238}," %(levelname)s",[1127,1932,1933],{"class":1238}," %(message)s",[1127,1935,1162],{"class":1154},[1127,1937,1172],{"class":1144},[1127,1939,1940],{"class":1129,"line":1438},[1127,1941,1296],{"class":1144},[1127,1943,1944],{"class":1129,"line":1452},[1127,1945,1361],{"class":1144},[1127,1947,1948,1950,1953,1955,1957],{"class":1129,"line":1472},[1127,1949,1155],{"class":1154},[1127,1951,1952],{"class":1158},"filters",[1127,1954,1162],{"class":1154},[1127,1956,1165],{"class":1144},[1127,1958,1148],{"class":1144},[1127,1960,1961,1963,1966,1968,1970],{"class":1129,"line":1493},[1127,1962,1210],{"class":1154},[1127,1964,1965],{"class":1158},"require_debug_false",[1127,1967,1162],{"class":1154},[1127,1969,1165],{"class":1144},[1127,1971,1148],{"class":1144},[1127,1973,1974,1976,1978,1980,1982,1984,1987,1989],{"class":1129,"line":1512},[1127,1975,1225],{"class":1154},[1127,1977,1896],{"class":1158},[1127,1979,1162],{"class":1154},[1127,1981,1165],{"class":1144},[1127,1983,1235],{"class":1154},[1127,1985,1986],{"class":1158},"django.utils.log.RequireDebugFalse",[1127,1988,1162],{"class":1154},[1127,1990,1172],{"class":1144},[1127,1992,1993],{"class":1129,"line":1517},[1127,1994,1296],{"class":1144},[1127,1996,1997,1999,2002,2004,2006],{"class":1129,"line":1522},[1127,1998,1210],{"class":1154},[1127,2000,2001],{"class":1158},"require_debug_true",[1127,2003,1162],{"class":1154},[1127,2005,1165],{"class":1144},[1127,2007,1148],{"class":1144},[1127,2009,2010,2012,2014,2016,2018,2020,2023,2025],{"class":1129,"line":1536},[1127,2011,1225],{"class":1154},[1127,2013,1896],{"class":1158},[1127,2015,1162],{"class":1154},[1127,2017,1165],{"class":1144},[1127,2019,1235],{"class":1154},[1127,2021,2022],{"class":1158},"django.utils.log.RequireDebugTrue",[1127,2024,1162],{"class":1154},[1127,2026,1172],{"class":1144},[1127,2028,2029],{"class":1129,"line":1549},[1127,2030,1296],{"class":1144},[1127,2032,2033],{"class":1129,"line":1581},[1127,2034,1361],{"class":1144},[1127,2036,2037,2039,2041,2043,2045],{"class":1129,"line":1602},[1127,2038,1155],{"class":1154},[1127,2040,1369],{"class":1158},[1127,2042,1162],{"class":1154},[1127,2044,1165],{"class":1144},[1127,2046,1148],{"class":1144},[1127,2048,2049,2051,2053,2055,2057],{"class":1129,"line":1619},[1127,2050,1210],{"class":1154},[1127,2052,1383],{"class":1158},[1127,2054,1162],{"class":1154},[1127,2056,1165],{"class":1144},[1127,2058,1148],{"class":1144},[1127,2060,2061,2063,2065,2067,2069,2071,2073,2075],{"class":1129,"line":1624},[1127,2062,1225],{"class":1154},[1127,2064,1586],{"class":1158},[1127,2066,1162],{"class":1154},[1127,2068,1165],{"class":1144},[1127,2070,1235],{"class":1154},[1127,2072,1595],{"class":1158},[1127,2074,1162],{"class":1154},[1127,2076,1172],{"class":1144},[1127,2078,2079,2081,2083,2085,2087,2089,2091,2093,2095],{"class":1129,"line":1629},[1127,2080,1225],{"class":1154},[1127,2082,1952],{"class":1158},[1127,2084,1162],{"class":1154},[1127,2086,1165],{"class":1144},[1127,2088,1560],{"class":1144},[1127,2090,1162],{"class":1154},[1127,2092,2001],{"class":1158},[1127,2094,1162],{"class":1154},[1127,2096,1578],{"class":1144},[1127,2098,2100,2102,2104,2106,2108,2110,2112,2114],{"class":1129,"line":2099},34,[1127,2101,1225],{"class":1154},[1127,2103,1397],{"class":1158},[1127,2105,1162],{"class":1154},[1127,2107,1165],{"class":1144},[1127,2109,1235],{"class":1154},[1127,2111,1406],{"class":1158},[1127,2113,1162],{"class":1154},[1127,2115,1172],{"class":1144},[1127,2117,2119,2121,2123,2125,2127,2129,2131,2133],{"class":1129,"line":2118},35,[1127,2120,1225],{"class":1154},[1127,2122,1418],{"class":1158},[1127,2124,1162],{"class":1154},[1127,2126,1165],{"class":1144},[1127,2128,1235],{"class":1154},[1127,2130,1304],{"class":1158},[1127,2132,1162],{"class":1154},[1127,2134,1172],{"class":1144},[1127,2136,2138],{"class":1129,"line":2137},36,[1127,2139,1296],{"class":1144},[1127,2141,2143,2145,2147,2149,2151],{"class":1129,"line":2142},37,[1127,2144,1210],{"class":1154},[1127,2146,1443],{"class":1158},[1127,2148,1162],{"class":1154},[1127,2150,1165],{"class":1144},[1127,2152,1148],{"class":1144},[1127,2154,2156,2158,2160,2162,2164,2166,2168,2170],{"class":1129,"line":2155},38,[1127,2157,1225],{"class":1154},[1127,2159,1586],{"class":1158},[1127,2161,1162],{"class":1154},[1127,2163,1165],{"class":1144},[1127,2165,1235],{"class":1154},[1127,2167,1595],{"class":1158},[1127,2169,1162],{"class":1154},[1127,2171,1172],{"class":1144},[1127,2173,2175,2177,2179,2181,2183,2185,2188,2190],{"class":1129,"line":2174},39,[1127,2176,1225],{"class":1154},[1127,2178,1397],{"class":1158},[1127,2180,1162],{"class":1154},[1127,2182,1165],{"class":1144},[1127,2184,1235],{"class":1154},[1127,2186,2187],{"class":1158},"logging.handlers.RotatingFileHandler",[1127,2189,1162],{"class":1154},[1127,2191,1172],{"class":1144},[1127,2193,2195,2197,2199,2201,2203,2206,2208,2212,2214,2218,2221,2225,2227,2229,2232,2234,2236,2238,2240,2242],{"class":1129,"line":2194},40,[1127,2196,1225],{"class":1154},[1127,2198,1477],{"class":1158},[1127,2200,1162],{"class":1154},[1127,2202,1165],{"class":1144},[1127,2204,2205],{"class":1654}," os",[1127,2207,1752],{"class":1144},[1127,2209,2211],{"class":2210},"sBPpx","path",[1127,2213,1752],{"class":1144},[1127,2215,2217],{"class":2216},"siWMO","join",[1127,2219,2220],{"class":1144},"(",[1127,2222,2224],{"class":2223},"s6DHA","BASE_DIR",[1127,2226,1569],{"class":1144},[1127,2228,1235],{"class":1154},[1127,2230,2231],{"class":1158},"logs",[1127,2233,1162],{"class":1154},[1127,2235,1569],{"class":1144},[1127,2237,1235],{"class":1154},[1127,2239,1486],{"class":1158},[1127,2241,1162],{"class":1154},[1127,2243,2244],{"class":1144},"),\n",[1127,2246,2248,2250,2253,2255,2257,2260,2264,2266,2268,2271,2273],{"class":1129,"line":2247},41,[1127,2249,1225],{"class":1154},[1127,2251,2252],{"class":1158},"maxBytes",[1127,2254,1162],{"class":1154},[1127,2256,1165],{"class":1144},[1127,2258,2259],{"class":1168}," 1024",[1127,2261,2263],{"class":2262},"sVsLi"," *",[1127,2265,2259],{"class":1168},[1127,2267,2263],{"class":2262},[1127,2269,2270],{"class":1168}," 15",[1127,2272,1569],{"class":1144},[1127,2274,2275],{"class":1133},"  # 15MB\n",[1127,2277,2279,2281,2284,2286,2288,2291],{"class":1129,"line":2278},42,[1127,2280,1225],{"class":1154},[1127,2282,2283],{"class":1158},"backupCount",[1127,2285,1162],{"class":1154},[1127,2287,1165],{"class":1144},[1127,2289,2290],{"class":1168}," 10",[1127,2292,1172],{"class":1144},[1127,2294,2296,2298,2300,2302,2304,2306,2308,2310],{"class":1129,"line":2295},43,[1127,2297,1225],{"class":1154},[1127,2299,1418],{"class":1158},[1127,2301,1162],{"class":1154},[1127,2303,1165],{"class":1144},[1127,2305,1235],{"class":1154},[1127,2307,1213],{"class":1158},[1127,2309,1162],{"class":1154},[1127,2311,1172],{"class":1144},[1127,2313,2315],{"class":1129,"line":2314},44,[1127,2316,1296],{"class":1144},[1127,2318,2320,2322,2325,2327,2329],{"class":1129,"line":2319},45,[1127,2321,1210],{"class":1154},[1127,2323,2324],{"class":1158},"error_file",[1127,2326,1162],{"class":1154},[1127,2328,1165],{"class":1144},[1127,2330,1148],{"class":1144},[1127,2332,2334,2336,2338,2340,2342,2344,2347,2349],{"class":1129,"line":2333},46,[1127,2335,1225],{"class":1154},[1127,2337,1586],{"class":1158},[1127,2339,1162],{"class":1154},[1127,2341,1165],{"class":1144},[1127,2343,1235],{"class":1154},[1127,2345,2346],{"class":1158},"ERROR",[1127,2348,1162],{"class":1154},[1127,2350,1172],{"class":1144},[1127,2352,2354,2356,2358,2360,2362,2364,2366,2368],{"class":1129,"line":2353},47,[1127,2355,1225],{"class":1154},[1127,2357,1397],{"class":1158},[1127,2359,1162],{"class":1154},[1127,2361,1165],{"class":1144},[1127,2363,1235],{"class":1154},[1127,2365,2187],{"class":1158},[1127,2367,1162],{"class":1154},[1127,2369,1172],{"class":1144},[1127,2371,2373,2375,2377,2379,2381,2383,2385,2387,2389,2391,2393,2395,2397,2399,2401,2403,2405,2407,2410,2412],{"class":1129,"line":2372},48,[1127,2374,1225],{"class":1154},[1127,2376,1477],{"class":1158},[1127,2378,1162],{"class":1154},[1127,2380,1165],{"class":1144},[1127,2382,2205],{"class":1654},[1127,2384,1752],{"class":1144},[1127,2386,2211],{"class":2210},[1127,2388,1752],{"class":1144},[1127,2390,2217],{"class":2216},[1127,2392,2220],{"class":1144},[1127,2394,2224],{"class":2223},[1127,2396,1569],{"class":1144},[1127,2398,1235],{"class":1154},[1127,2400,2231],{"class":1158},[1127,2402,1162],{"class":1154},[1127,2404,1569],{"class":1144},[1127,2406,1235],{"class":1154},[1127,2408,2409],{"class":1158},"django_errors.log",[1127,2411,1162],{"class":1154},[1127,2413,2244],{"class":1144},[1127,2415,2417,2419,2421,2423,2425,2427,2429,2431,2433,2435,2437],{"class":1129,"line":2416},49,[1127,2418,1225],{"class":1154},[1127,2420,2252],{"class":1158},[1127,2422,1162],{"class":1154},[1127,2424,1165],{"class":1144},[1127,2426,2259],{"class":1168},[1127,2428,2263],{"class":2262},[1127,2430,2259],{"class":1168},[1127,2432,2263],{"class":2262},[1127,2434,2270],{"class":1168},[1127,2436,1569],{"class":1144},[1127,2438,2275],{"class":1133},[1127,2440,2442,2444,2446,2448,2450,2452],{"class":1129,"line":2441},50,[1127,2443,1225],{"class":1154},[1127,2445,2283],{"class":1158},[1127,2447,1162],{"class":1154},[1127,2449,1165],{"class":1144},[1127,2451,2290],{"class":1168},[1127,2453,1172],{"class":1144},[1127,2455,2457,2459,2461,2463,2465,2467,2469,2471],{"class":1129,"line":2456},51,[1127,2458,1225],{"class":1154},[1127,2460,1418],{"class":1158},[1127,2462,1162],{"class":1154},[1127,2464,1165],{"class":1144},[1127,2466,1235],{"class":1154},[1127,2468,1213],{"class":1158},[1127,2470,1162],{"class":1154},[1127,2472,1172],{"class":1144},[1127,2474,2476],{"class":1129,"line":2475},52,[1127,2477,1296],{"class":1144},[1127,2479,2481,2483,2486,2488,2490],{"class":1129,"line":2480},53,[1127,2482,1210],{"class":1154},[1127,2484,2485],{"class":1158},"mail_admins",[1127,2487,1162],{"class":1154},[1127,2489,1165],{"class":1144},[1127,2491,1148],{"class":1144},[1127,2493,2495,2497,2499,2501,2503,2505,2507,2509],{"class":1129,"line":2494},54,[1127,2496,1225],{"class":1154},[1127,2498,1586],{"class":1158},[1127,2500,1162],{"class":1154},[1127,2502,1165],{"class":1144},[1127,2504,1235],{"class":1154},[1127,2506,2346],{"class":1158},[1127,2508,1162],{"class":1154},[1127,2510,1172],{"class":1144},[1127,2512,2514,2516,2518,2520,2522,2524,2526,2528,2530],{"class":1129,"line":2513},55,[1127,2515,1225],{"class":1154},[1127,2517,1952],{"class":1158},[1127,2519,1162],{"class":1154},[1127,2521,1165],{"class":1144},[1127,2523,1560],{"class":1144},[1127,2525,1162],{"class":1154},[1127,2527,1965],{"class":1158},[1127,2529,1162],{"class":1154},[1127,2531,1578],{"class":1144},[1127,2533,2535,2537,2539,2541,2543,2545,2548,2550],{"class":1129,"line":2534},56,[1127,2536,1225],{"class":1154},[1127,2538,1397],{"class":1158},[1127,2540,1162],{"class":1154},[1127,2542,1165],{"class":1144},[1127,2544,1235],{"class":1154},[1127,2546,2547],{"class":1158},"django.utils.log.AdminEmailHandler",[1127,2549,1162],{"class":1154},[1127,2551,1172],{"class":1144},[1127,2553,2555,2557,2560,2562,2564,2566],{"class":1129,"line":2554},57,[1127,2556,1225],{"class":1154},[1127,2558,2559],{"class":1158},"include_html",[1127,2561,1162],{"class":1154},[1127,2563,1165],{"class":1144},[1127,2565,1614],{"class":1187},[1127,2567,1172],{"class":1144},[1127,2569,2571],{"class":1129,"line":2570},58,[1127,2572,1296],{"class":1144},[1127,2574,2576],{"class":1129,"line":2575},59,[1127,2577,1361],{"class":1144},[1127,2579,2581,2583,2585,2587,2589],{"class":1129,"line":2580},60,[1127,2582,1155],{"class":1154},[1127,2584,1527],{"class":1158},[1127,2586,1162],{"class":1154},[1127,2588,1165],{"class":1144},[1127,2590,1148],{"class":1144},[1127,2592,2594,2596,2598,2600,2602],{"class":1129,"line":2593},61,[1127,2595,1210],{"class":1154},[1127,2597,1077],{"class":1158},[1127,2599,1162],{"class":1154},[1127,2601,1165],{"class":1144},[1127,2603,1148],{"class":1144},[1127,2605,2607,2609,2611,2613,2615,2617,2619,2621,2623,2625,2627,2629,2631],{"class":1129,"line":2606},62,[1127,2608,1225],{"class":1154},[1127,2610,1369],{"class":1158},[1127,2612,1162],{"class":1154},[1127,2614,1165],{"class":1144},[1127,2616,1560],{"class":1144},[1127,2618,1162],{"class":1154},[1127,2620,1383],{"class":1158},[1127,2622,1162],{"class":1154},[1127,2624,1569],{"class":1144},[1127,2626,1235],{"class":1154},[1127,2628,1443],{"class":1158},[1127,2630,1162],{"class":1154},[1127,2632,1578],{"class":1144},[1127,2634,2636,2638,2640,2642,2644,2646,2648,2650],{"class":1129,"line":2635},63,[1127,2637,1225],{"class":1154},[1127,2639,1586],{"class":1158},[1127,2641,1162],{"class":1154},[1127,2643,1165],{"class":1144},[1127,2645,1235],{"class":1154},[1127,2647,1595],{"class":1158},[1127,2649,1162],{"class":1154},[1127,2651,1172],{"class":1144},[1127,2653,2655,2657,2659,2661,2663,2665],{"class":1129,"line":2654},64,[1127,2656,1225],{"class":1154},[1127,2658,1607],{"class":1158},[1127,2660,1162],{"class":1154},[1127,2662,1165],{"class":1144},[1127,2664,1188],{"class":1187},[1127,2666,1172],{"class":1144},[1127,2668,2670],{"class":1129,"line":2669},65,[1127,2671,1296],{"class":1144},[1127,2673,2675,2677,2679,2681,2683],{"class":1129,"line":2674},66,[1127,2676,1210],{"class":1154},[1127,2678,1083],{"class":1158},[1127,2680,1162],{"class":1154},[1127,2682,1165],{"class":1144},[1127,2684,1148],{"class":1144},[1127,2686,2688,2690,2692,2694,2696,2698,2700,2702,2704,2706,2708,2710,2712],{"class":1129,"line":2687},67,[1127,2689,1225],{"class":1154},[1127,2691,1369],{"class":1158},[1127,2693,1162],{"class":1154},[1127,2695,1165],{"class":1144},[1127,2697,1560],{"class":1144},[1127,2699,1162],{"class":1154},[1127,2701,2324],{"class":1158},[1127,2703,1162],{"class":1154},[1127,2705,1569],{"class":1144},[1127,2707,1235],{"class":1154},[1127,2709,2485],{"class":1158},[1127,2711,1162],{"class":1154},[1127,2713,1578],{"class":1144},[1127,2715,2717,2719,2721,2723,2725,2727,2729,2731],{"class":1129,"line":2716},68,[1127,2718,1225],{"class":1154},[1127,2720,1586],{"class":1158},[1127,2722,1162],{"class":1154},[1127,2724,1165],{"class":1144},[1127,2726,1235],{"class":1154},[1127,2728,2346],{"class":1158},[1127,2730,1162],{"class":1154},[1127,2732,1172],{"class":1144},[1127,2734,2736,2738,2740,2742,2744,2746],{"class":1129,"line":2735},69,[1127,2737,1225],{"class":1154},[1127,2739,1607],{"class":1158},[1127,2741,1162],{"class":1154},[1127,2743,1165],{"class":1144},[1127,2745,1188],{"class":1187},[1127,2747,1172],{"class":1144},[1127,2749,2751],{"class":1129,"line":2750},70,[1127,2752,1296],{"class":1144},[1127,2754,2756,2758,2760,2762,2764],{"class":1129,"line":2755},71,[1127,2757,1210],{"class":1154},[1127,2759,1101],{"class":1158},[1127,2761,1162],{"class":1154},[1127,2763,1165],{"class":1144},[1127,2765,1148],{"class":1144},[1127,2767,2769,2771,2773,2775,2777,2779,2781,2783,2785],{"class":1129,"line":2768},72,[1127,2770,1225],{"class":1154},[1127,2772,1369],{"class":1158},[1127,2774,1162],{"class":1154},[1127,2776,1165],{"class":1144},[1127,2778,1560],{"class":1144},[1127,2780,1162],{"class":1154},[1127,2782,1383],{"class":1158},[1127,2784,1162],{"class":1154},[1127,2786,1578],{"class":1144},[1127,2788,2790,2792,2794,2796,2798,2800,2803,2805,2808,2811,2814,2816,2818,2820],{"class":1129,"line":2789},73,[1127,2791,1225],{"class":1154},[1127,2793,1586],{"class":1158},[1127,2795,1162],{"class":1154},[1127,2797,1165],{"class":1144},[1127,2799,1235],{"class":1154},[1127,2801,2802],{"class":1158},"DEBUG",[1127,2804,1162],{"class":1154},[1127,2806,2807],{"class":1650}," if",[1127,2809,2810],{"class":1140}," DEBUG",[1127,2812,2813],{"class":1650}," else",[1127,2815,1235],{"class":1154},[1127,2817,1595],{"class":1158},[1127,2819,1162],{"class":1154},[1127,2821,1172],{"class":1144},[1127,2823,2825,2827,2829,2831,2833,2835],{"class":1129,"line":2824},74,[1127,2826,1225],{"class":1154},[1127,2828,1607],{"class":1158},[1127,2830,1162],{"class":1154},[1127,2832,1165],{"class":1144},[1127,2834,1188],{"class":1187},[1127,2836,1172],{"class":1144},[1127,2838,2840],{"class":1129,"line":2839},75,[1127,2841,1296],{"class":1144},[1127,2843,2845,2847,2850,2852,2854],{"class":1129,"line":2844},76,[1127,2846,1210],{"class":1154},[1127,2848,2849],{"class":1158},"myapp",[1127,2851,1162],{"class":1154},[1127,2853,1165],{"class":1144},[1127,2855,1148],{"class":1144},[1127,2857,2859,2861,2863,2865,2867,2869,2871,2873,2875,2877,2879,2881,2883,2885,2887,2889,2891],{"class":1129,"line":2858},77,[1127,2860,1225],{"class":1154},[1127,2862,1369],{"class":1158},[1127,2864,1162],{"class":1154},[1127,2866,1165],{"class":1144},[1127,2868,1560],{"class":1144},[1127,2870,1162],{"class":1154},[1127,2872,1383],{"class":1158},[1127,2874,1162],{"class":1154},[1127,2876,1569],{"class":1144},[1127,2878,1235],{"class":1154},[1127,2880,1443],{"class":1158},[1127,2882,1162],{"class":1154},[1127,2884,1569],{"class":1144},[1127,2886,1235],{"class":1154},[1127,2888,2324],{"class":1158},[1127,2890,1162],{"class":1154},[1127,2892,1578],{"class":1144},[1127,2894,2896,2898,2900,2902,2904,2906,2908,2910,2912,2914,2916,2918,2920,2922],{"class":1129,"line":2895},78,[1127,2897,1225],{"class":1154},[1127,2899,1586],{"class":1158},[1127,2901,1162],{"class":1154},[1127,2903,1165],{"class":1144},[1127,2905,1235],{"class":1154},[1127,2907,2802],{"class":1158},[1127,2909,1162],{"class":1154},[1127,2911,2807],{"class":1650},[1127,2913,2810],{"class":1140},[1127,2915,2813],{"class":1650},[1127,2917,1235],{"class":1154},[1127,2919,1595],{"class":1158},[1127,2921,1162],{"class":1154},[1127,2923,1172],{"class":1144},[1127,2925,2927,2929,2931,2933,2935,2937],{"class":1129,"line":2926},79,[1127,2928,1225],{"class":1154},[1127,2930,1607],{"class":1158},[1127,2932,1162],{"class":1154},[1127,2934,1165],{"class":1144},[1127,2936,1188],{"class":1187},[1127,2938,1172],{"class":1144},[1127,2940,2942],{"class":1129,"line":2941},80,[1127,2943,1296],{"class":1144},[1127,2945,2947],{"class":1129,"line":2946},81,[1127,2948,1361],{"class":1144},[1127,2950,2952,2954,2957,2959,2961],{"class":1129,"line":2951},82,[1127,2953,1155],{"class":1154},[1127,2955,2956],{"class":1158},"root",[1127,2958,1162],{"class":1154},[1127,2960,1165],{"class":1144},[1127,2962,1148],{"class":1144},[1127,2964,2966,2968,2970,2972,2974,2976,2978,2980,2982,2984,2986,2988,2990],{"class":1129,"line":2965},83,[1127,2967,1210],{"class":1154},[1127,2969,1369],{"class":1158},[1127,2971,1162],{"class":1154},[1127,2973,1165],{"class":1144},[1127,2975,1560],{"class":1144},[1127,2977,1162],{"class":1154},[1127,2979,1383],{"class":1158},[1127,2981,1162],{"class":1154},[1127,2983,1569],{"class":1144},[1127,2985,1235],{"class":1154},[1127,2987,1443],{"class":1158},[1127,2989,1162],{"class":1154},[1127,2991,1578],{"class":1144},[1127,2993,2995,2997,2999,3001,3003,3005,3007,3009],{"class":1129,"line":2994},84,[1127,2996,1210],{"class":1154},[1127,2998,1586],{"class":1158},[1127,3000,1162],{"class":1154},[1127,3002,1165],{"class":1144},[1127,3004,1235],{"class":1154},[1127,3006,1595],{"class":1158},[1127,3008,1162],{"class":1154},[1127,3010,1172],{"class":1144},[1127,3012,3014],{"class":1129,"line":3013},85,[1127,3015,1361],{"class":1144},[1127,3017,3019],{"class":1129,"line":3018},86,[1127,3020,1632],{"class":1144},[1030,3022,3024],{"id":3023},"using-loggers-in-code","Using Loggers in Code",[1038,3026,3028],{"id":3027},"basic-logging","Basic Logging",[1118,3030,3032],{"className":1120,"code":3031,"language":1122,"meta":1123,"style":1123},"# views.py\nimport logging\n\nlogger = logging.getLogger(__name__)\n\ndef my_view(request):\n    logger.debug('Debug message - detailed information')\n    logger.info('Info message - general information')\n    logger.warning('Warning message - something unexpected')\n    logger.error('Error message - something failed')\n    logger.critical('Critical message - serious problem')\n    \n    try:\n        # Your code here\n        result = perform_operation()\n        logger.info(f'Operation completed successfully: {result}')\n        return JsonResponse({'status': 'success', 'result': result})\n    except Exception as e:\n        logger.exception('Operation failed with exception')\n        return JsonResponse({'status': 'error', 'message': str(e)}, status=500)\n",[1075,3033,3034,3039,3046,3050,3075,3079,3097,3118,3138,3158,3178,3198,3203,3211,3216,3229,3257,3300,3317,3337],{"__ignoreMap":1123},[1127,3035,3036],{"class":1129,"line":1130},[1127,3037,3038],{"class":1133},"# views.py\n",[1127,3040,3041,3043],{"class":1129,"line":1137},[1127,3042,1651],{"class":1650},[1127,3044,3045],{"class":1654}," logging\n",[1127,3047,3048],{"class":1129,"line":1151},[1127,3049,1661],{"emptyLinePlaceholder":1660},[1127,3051,3052,3055,3058,3061,3063,3066,3068,3072],{"class":1129,"line":1175},[1127,3053,3054],{"class":1654},"logger ",[1127,3056,3057],{"class":1144},"=",[1127,3059,3060],{"class":1654}," logging",[1127,3062,1752],{"class":1144},[1127,3064,3065],{"class":2216},"getLogger",[1127,3067,2220],{"class":1144},[1127,3069,3071],{"class":3070},"s131V","__name__",[1127,3073,3074],{"class":1144},")\n",[1127,3076,3077],{"class":1129,"line":1193},[1127,3078,1661],{"emptyLinePlaceholder":1660},[1127,3080,3081,3084,3088,3090,3094],{"class":1129,"line":1207},[1127,3082,3083],{"class":1251},"def",[1127,3085,3087],{"class":3086},"sljsM"," my_view",[1127,3089,2220],{"class":1144},[1127,3091,3093],{"class":3092},"sCyAa","request",[1127,3095,3096],{"class":1144},"):\n",[1127,3098,3099,3102,3104,3107,3109,3111,3114,3116],{"class":1129,"line":1222},[1127,3100,3101],{"class":1654},"    logger",[1127,3103,1752],{"class":1144},[1127,3105,3106],{"class":2216},"debug",[1127,3108,2220],{"class":1144},[1127,3110,1162],{"class":1154},[1127,3112,3113],{"class":1158},"Debug message - detailed information",[1127,3115,1162],{"class":1154},[1127,3117,3074],{"class":1144},[1127,3119,3120,3122,3124,3127,3129,3131,3134,3136],{"class":1129,"line":1272},[1127,3121,3101],{"class":1654},[1127,3123,1752],{"class":1144},[1127,3125,3126],{"class":2216},"info",[1127,3128,2220],{"class":1144},[1127,3130,1162],{"class":1154},[1127,3132,3133],{"class":1158},"Info message - general information",[1127,3135,1162],{"class":1154},[1127,3137,3074],{"class":1144},[1127,3139,3140,3142,3144,3147,3149,3151,3154,3156],{"class":1129,"line":1293},[1127,3141,3101],{"class":1654},[1127,3143,1752],{"class":1144},[1127,3145,3146],{"class":2216},"warning",[1127,3148,2220],{"class":1144},[1127,3150,1162],{"class":1154},[1127,3152,3153],{"class":1158},"Warning message - something unexpected",[1127,3155,1162],{"class":1154},[1127,3157,3074],{"class":1144},[1127,3159,3160,3162,3164,3167,3169,3171,3174,3176],{"class":1129,"line":1299},[1127,3161,3101],{"class":1654},[1127,3163,1752],{"class":1144},[1127,3165,3166],{"class":2216},"error",[1127,3168,2220],{"class":1144},[1127,3170,1162],{"class":1154},[1127,3172,3173],{"class":1158},"Error message - something failed",[1127,3175,1162],{"class":1154},[1127,3177,3074],{"class":1144},[1127,3179,3180,3182,3184,3187,3189,3191,3194,3196],{"class":1129,"line":1313},[1127,3181,3101],{"class":1654},[1127,3183,1752],{"class":1144},[1127,3185,3186],{"class":2216},"critical",[1127,3188,2220],{"class":1144},[1127,3190,1162],{"class":1154},[1127,3192,3193],{"class":1158},"Critical message - serious problem",[1127,3195,1162],{"class":1154},[1127,3197,3074],{"class":1144},[1127,3199,3200],{"class":1129,"line":1334},[1127,3201,3202],{"class":1654},"    \n",[1127,3204,3205,3208],{"class":1129,"line":1353},[1127,3206,3207],{"class":1650},"    try",[1127,3209,3210],{"class":1144},":\n",[1127,3212,3213],{"class":1129,"line":1358},[1127,3214,3215],{"class":1133},"        # Your code here\n",[1127,3217,3218,3221,3223,3226],{"class":1129,"line":1364},[1127,3219,3220],{"class":1654},"        result ",[1127,3222,3057],{"class":1144},[1127,3224,3225],{"class":2216}," perform_operation",[1127,3227,3228],{"class":1144},"()\n",[1127,3230,3231,3234,3236,3238,3240,3243,3246,3248,3251,3253,3255],{"class":1129,"line":1378},[1127,3232,3233],{"class":1654},"        logger",[1127,3235,1752],{"class":1144},[1127,3237,3126],{"class":2216},[1127,3239,2220],{"class":1144},[1127,3241,3242],{"class":1251},"f",[1127,3244,3245],{"class":1158},"'Operation completed successfully: ",[1127,3247,1286],{"class":1238},[1127,3249,3250],{"class":2216},"result",[1127,3252,1255],{"class":1238},[1127,3254,1162],{"class":1158},[1127,3256,3074],{"class":1144},[1127,3258,3259,3262,3265,3268,3270,3273,3275,3277,3279,3282,3284,3286,3288,3290,3292,3294,3297],{"class":1129,"line":1392},[1127,3260,3261],{"class":1650},"        return",[1127,3263,3264],{"class":2216}," JsonResponse",[1127,3266,3267],{"class":1144},"({",[1127,3269,1162],{"class":1154},[1127,3271,3272],{"class":1158},"status",[1127,3274,1162],{"class":1154},[1127,3276,1165],{"class":1144},[1127,3278,1235],{"class":1154},[1127,3280,3281],{"class":1158},"success",[1127,3283,1162],{"class":1154},[1127,3285,1569],{"class":1144},[1127,3287,1235],{"class":1154},[1127,3289,3250],{"class":1158},[1127,3291,1162],{"class":1154},[1127,3293,1165],{"class":1144},[1127,3295,3296],{"class":2216}," result",[1127,3298,3299],{"class":1144},"})\n",[1127,3301,3302,3305,3309,3312,3315],{"class":1129,"line":1413},[1127,3303,3304],{"class":1650},"    except",[1127,3306,3308],{"class":3307},"sa2tF"," Exception",[1127,3310,3311],{"class":1650}," as",[1127,3313,3314],{"class":1654}," e",[1127,3316,3210],{"class":1144},[1127,3318,3319,3321,3323,3326,3328,3330,3333,3335],{"class":1129,"line":1433},[1127,3320,3233],{"class":1654},[1127,3322,1752],{"class":1144},[1127,3324,3325],{"class":2216},"exception",[1127,3327,2220],{"class":1144},[1127,3329,1162],{"class":1154},[1127,3331,3332],{"class":1158},"Operation failed with exception",[1127,3334,1162],{"class":1154},[1127,3336,3074],{"class":1144},[1127,3338,3339,3341,3343,3345,3347,3349,3351,3353,3355,3357,3359,3361,3363,3366,3368,3370,3373,3375,3378,3381,3385,3387,3390],{"class":1129,"line":1438},[1127,3340,3261],{"class":1650},[1127,3342,3264],{"class":2216},[1127,3344,3267],{"class":1144},[1127,3346,1162],{"class":1154},[1127,3348,3272],{"class":1158},[1127,3350,1162],{"class":1154},[1127,3352,1165],{"class":1144},[1127,3354,1235],{"class":1154},[1127,3356,3166],{"class":1158},[1127,3358,1162],{"class":1154},[1127,3360,1569],{"class":1144},[1127,3362,1235],{"class":1154},[1127,3364,3365],{"class":1158},"message",[1127,3367,1162],{"class":1154},[1127,3369,1165],{"class":1144},[1127,3371,3372],{"class":3307}," str",[1127,3374,2220],{"class":1144},[1127,3376,3377],{"class":2216},"e",[1127,3379,3380],{"class":1144},")},",[1127,3382,3384],{"class":3383},"sqOPj"," status",[1127,3386,3057],{"class":1144},[1127,3388,3389],{"class":1168},"500",[1127,3391,3074],{"class":1144},[1038,3393,3395],{"id":3394},"structured-logging","Structured Logging",[1118,3397,3399],{"className":1120,"code":3398,"language":1122,"meta":1123,"style":1123},"# utils/logging.py\nimport logging\nimport json\nfrom datetime import datetime\n\nclass StructuredLogger:\n    def __init__(self, name):\n        self.logger = logging.getLogger(name)\n    \n    def log_event(self, event_type, level='info', **kwargs):\n        \"\"\"Log structured event with metadata\"\"\"\n        log_data = {\n            'timestamp': datetime.utcnow().isoformat(),\n            'event_type': event_type,\n            **kwargs\n        }\n        \n        log_message = json.dumps(log_data)\n        \n        if level == 'debug':\n            self.logger.debug(log_message)\n        elif level == 'info':\n            self.logger.info(log_message)\n        elif level == 'warning':\n            self.logger.warning(log_message)\n        elif level == 'error':\n            self.logger.error(log_message)\n        elif level == 'critical':\n            self.logger.critical(log_message)\n    \n    def log_request(self, request, response_time=None, status_code=None):\n        \"\"\"Log HTTP request details\"\"\"\n        self.log_event(\n            'http_request',\n            method=request.method,\n            path=request.path,\n            user=str(request.user),\n            ip_address=self.get_client_ip(request),\n            response_time=response_time,\n            status_code=status_code\n        )\n    \n    @staticmethod\n    def get_client_ip(request):\n        x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')\n        if x_forwarded_for:\n            ip = x_forwarded_for.split(',')[0]\n        else:\n            ip = request.META.get('REMOTE_ADDR')\n        return ip\n\n# Usage\nlogger = StructuredLogger(__name__)\n\ndef my_view(request):\n    start_time = time.time()\n    \n    try:\n        # Process request\n        result = process_request(request)\n        \n        response_time = time.time() - start_time\n        logger.log_request(request, response_time=response_time, status_code=200)\n        \n        return JsonResponse(result)\n    except Exception as e:\n        response_time = time.time() - start_time\n        logger.log_event('request_error', level='error',\n                        error=str(e),\n                        path=request.path,\n                        response_time=response_time)\n        return JsonResponse({'error': str(e)}, status=500)\n",[1075,3400,3401,3406,3412,3419,3432,3436,3446,3468,3493,3497,3536,3549,3558,3586,3601,3609,3614,3619,3641,3645,3664,3684,3701,3719,3735,3753,3769,3787,3803,3821,3825,3862,3871,3883,3894,3910,3925,3946,3966,3978,3988,3993,3997,4005,4018,4049,4058,4089,4096,4123,4130,4134,4139,4153,4157,4169,4186,4190,4196,4201,4216,4220,4241,4273,4277,4289,4301,4319,4350,4365,4380,4391],{"__ignoreMap":1123},[1127,3402,3403],{"class":1129,"line":1130},[1127,3404,3405],{"class":1133},"# utils/logging.py\n",[1127,3407,3408,3410],{"class":1129,"line":1137},[1127,3409,1651],{"class":1650},[1127,3411,3045],{"class":1654},[1127,3413,3414,3416],{"class":1129,"line":1151},[1127,3415,1651],{"class":1650},[1127,3417,3418],{"class":1654}," json\n",[1127,3420,3421,3424,3427,3429],{"class":1129,"line":1175},[1127,3422,3423],{"class":1650},"from",[1127,3425,3426],{"class":1654}," datetime ",[1127,3428,1651],{"class":1650},[1127,3430,3431],{"class":1654}," datetime\n",[1127,3433,3434],{"class":1129,"line":1193},[1127,3435,1661],{"emptyLinePlaceholder":1660},[1127,3437,3438,3440,3444],{"class":1129,"line":1207},[1127,3439,1397],{"class":1251},[1127,3441,3443],{"class":3442},"sD-vU"," StructuredLogger",[1127,3445,3210],{"class":1144},[1127,3447,3448,3451,3455,3457,3461,3463,3466],{"class":1129,"line":1222},[1127,3449,3450],{"class":1251},"    def",[1127,3452,3454],{"class":3453},"sJdAF"," __init__",[1127,3456,2220],{"class":1144},[1127,3458,3460],{"class":3459},"sRjD_","self",[1127,3462,1569],{"class":1144},[1127,3464,3465],{"class":3092}," name",[1127,3467,3096],{"class":1144},[1127,3469,3470,3473,3475,3478,3480,3482,3484,3486,3488,3491],{"class":1129,"line":1272},[1127,3471,3472],{"class":1140},"        self",[1127,3474,1752],{"class":1144},[1127,3476,3477],{"class":2210},"logger",[1127,3479,1145],{"class":1144},[1127,3481,3060],{"class":1654},[1127,3483,1752],{"class":1144},[1127,3485,3065],{"class":2216},[1127,3487,2220],{"class":1144},[1127,3489,3490],{"class":2216},"name",[1127,3492,3074],{"class":1144},[1127,3494,3495],{"class":1129,"line":1293},[1127,3496,3202],{"class":1654},[1127,3498,3499,3501,3504,3506,3508,3510,3513,3515,3518,3520,3522,3524,3526,3528,3531,3534],{"class":1129,"line":1299},[1127,3500,3450],{"class":1251},[1127,3502,3503],{"class":3086}," log_event",[1127,3505,2220],{"class":1144},[1127,3507,3460],{"class":3459},[1127,3509,1569],{"class":1144},[1127,3511,3512],{"class":3092}," event_type",[1127,3514,1569],{"class":1144},[1127,3516,3517],{"class":3092}," level",[1127,3519,3057],{"class":2262},[1127,3521,1162],{"class":1154},[1127,3523,3126],{"class":1158},[1127,3525,1162],{"class":1154},[1127,3527,1569],{"class":1144},[1127,3529,3530],{"class":2262}," **",[1127,3532,3533],{"class":3092},"kwargs",[1127,3535,3096],{"class":1144},[1127,3537,3538,3542,3546],{"class":1129,"line":1313},[1127,3539,3541],{"class":3540},"sm7ve","        \"\"\"",[1127,3543,3545],{"class":3544},"sVyVU","Log structured event with metadata",[1127,3547,3548],{"class":3540},"\"\"\"\n",[1127,3550,3551,3554,3556],{"class":1129,"line":1334},[1127,3552,3553],{"class":1654},"        log_data ",[1127,3555,3057],{"class":1144},[1127,3557,1148],{"class":1144},[1127,3559,3560,3562,3565,3567,3569,3572,3574,3577,3580,3583],{"class":1129,"line":1353},[1127,3561,1225],{"class":1154},[1127,3563,3564],{"class":1158},"timestamp",[1127,3566,1162],{"class":1154},[1127,3568,1165],{"class":1144},[1127,3570,3571],{"class":1654}," datetime",[1127,3573,1752],{"class":1144},[1127,3575,3576],{"class":2216},"utcnow",[1127,3578,3579],{"class":1144},"().",[1127,3581,3582],{"class":2216},"isoformat",[1127,3584,3585],{"class":1144},"(),\n",[1127,3587,3588,3590,3593,3595,3597,3599],{"class":1129,"line":1358},[1127,3589,1225],{"class":1154},[1127,3591,3592],{"class":1158},"event_type",[1127,3594,1162],{"class":1154},[1127,3596,1165],{"class":1144},[1127,3598,3512],{"class":1654},[1127,3600,1172],{"class":1144},[1127,3602,3603,3606],{"class":1129,"line":1364},[1127,3604,3605],{"class":2262},"            **",[1127,3607,3608],{"class":1654},"kwargs\n",[1127,3610,3611],{"class":1129,"line":1378},[1127,3612,3613],{"class":1144},"        }\n",[1127,3615,3616],{"class":1129,"line":1392},[1127,3617,3618],{"class":1654},"        \n",[1127,3620,3621,3624,3626,3629,3631,3634,3636,3639],{"class":1129,"line":1413},[1127,3622,3623],{"class":1654},"        log_message ",[1127,3625,3057],{"class":1144},[1127,3627,3628],{"class":1654}," json",[1127,3630,1752],{"class":1144},[1127,3632,3633],{"class":2216},"dumps",[1127,3635,2220],{"class":1144},[1127,3637,3638],{"class":2216},"log_data",[1127,3640,3074],{"class":1144},[1127,3642,3643],{"class":1129,"line":1433},[1127,3644,3618],{"class":1654},[1127,3646,3647,3650,3653,3656,3658,3660,3662],{"class":1129,"line":1438},[1127,3648,3649],{"class":1650},"        if",[1127,3651,3652],{"class":1654}," level ",[1127,3654,3655],{"class":2262},"==",[1127,3657,1235],{"class":1154},[1127,3659,3106],{"class":1158},[1127,3661,1162],{"class":1154},[1127,3663,3210],{"class":1144},[1127,3665,3666,3669,3671,3673,3675,3677,3679,3682],{"class":1129,"line":1452},[1127,3667,3668],{"class":1140},"            self",[1127,3670,1752],{"class":1144},[1127,3672,3477],{"class":2210},[1127,3674,1752],{"class":1144},[1127,3676,3106],{"class":2216},[1127,3678,2220],{"class":1144},[1127,3680,3681],{"class":2216},"log_message",[1127,3683,3074],{"class":1144},[1127,3685,3686,3689,3691,3693,3695,3697,3699],{"class":1129,"line":1472},[1127,3687,3688],{"class":1650},"        elif",[1127,3690,3652],{"class":1654},[1127,3692,3655],{"class":2262},[1127,3694,1235],{"class":1154},[1127,3696,3126],{"class":1158},[1127,3698,1162],{"class":1154},[1127,3700,3210],{"class":1144},[1127,3702,3703,3705,3707,3709,3711,3713,3715,3717],{"class":1129,"line":1493},[1127,3704,3668],{"class":1140},[1127,3706,1752],{"class":1144},[1127,3708,3477],{"class":2210},[1127,3710,1752],{"class":1144},[1127,3712,3126],{"class":2216},[1127,3714,2220],{"class":1144},[1127,3716,3681],{"class":2216},[1127,3718,3074],{"class":1144},[1127,3720,3721,3723,3725,3727,3729,3731,3733],{"class":1129,"line":1512},[1127,3722,3688],{"class":1650},[1127,3724,3652],{"class":1654},[1127,3726,3655],{"class":2262},[1127,3728,1235],{"class":1154},[1127,3730,3146],{"class":1158},[1127,3732,1162],{"class":1154},[1127,3734,3210],{"class":1144},[1127,3736,3737,3739,3741,3743,3745,3747,3749,3751],{"class":1129,"line":1517},[1127,3738,3668],{"class":1140},[1127,3740,1752],{"class":1144},[1127,3742,3477],{"class":2210},[1127,3744,1752],{"class":1144},[1127,3746,3146],{"class":2216},[1127,3748,2220],{"class":1144},[1127,3750,3681],{"class":2216},[1127,3752,3074],{"class":1144},[1127,3754,3755,3757,3759,3761,3763,3765,3767],{"class":1129,"line":1522},[1127,3756,3688],{"class":1650},[1127,3758,3652],{"class":1654},[1127,3760,3655],{"class":2262},[1127,3762,1235],{"class":1154},[1127,3764,3166],{"class":1158},[1127,3766,1162],{"class":1154},[1127,3768,3210],{"class":1144},[1127,3770,3771,3773,3775,3777,3779,3781,3783,3785],{"class":1129,"line":1536},[1127,3772,3668],{"class":1140},[1127,3774,1752],{"class":1144},[1127,3776,3477],{"class":2210},[1127,3778,1752],{"class":1144},[1127,3780,3166],{"class":2216},[1127,3782,2220],{"class":1144},[1127,3784,3681],{"class":2216},[1127,3786,3074],{"class":1144},[1127,3788,3789,3791,3793,3795,3797,3799,3801],{"class":1129,"line":1549},[1127,3790,3688],{"class":1650},[1127,3792,3652],{"class":1654},[1127,3794,3655],{"class":2262},[1127,3796,1235],{"class":1154},[1127,3798,3186],{"class":1158},[1127,3800,1162],{"class":1154},[1127,3802,3210],{"class":1144},[1127,3804,3805,3807,3809,3811,3813,3815,3817,3819],{"class":1129,"line":1581},[1127,3806,3668],{"class":1140},[1127,3808,1752],{"class":1144},[1127,3810,3477],{"class":2210},[1127,3812,1752],{"class":1144},[1127,3814,3186],{"class":2216},[1127,3816,2220],{"class":1144},[1127,3818,3681],{"class":2216},[1127,3820,3074],{"class":1144},[1127,3822,3823],{"class":1129,"line":1602},[1127,3824,3202],{"class":1654},[1127,3826,3827,3829,3832,3834,3836,3838,3841,3843,3846,3848,3851,3853,3856,3858,3860],{"class":1129,"line":1619},[1127,3828,3450],{"class":1251},[1127,3830,3831],{"class":3086}," log_request",[1127,3833,2220],{"class":1144},[1127,3835,3460],{"class":3459},[1127,3837,1569],{"class":1144},[1127,3839,3840],{"class":3092}," request",[1127,3842,1569],{"class":1144},[1127,3844,3845],{"class":3092}," response_time",[1127,3847,3057],{"class":2262},[1127,3849,3850],{"class":1187},"None",[1127,3852,1569],{"class":1144},[1127,3854,3855],{"class":3092}," status_code",[1127,3857,3057],{"class":2262},[1127,3859,3850],{"class":1187},[1127,3861,3096],{"class":1144},[1127,3863,3864,3866,3869],{"class":1129,"line":1624},[1127,3865,3541],{"class":3540},[1127,3867,3868],{"class":3544},"Log HTTP request details",[1127,3870,3548],{"class":3540},[1127,3872,3873,3875,3877,3880],{"class":1129,"line":1629},[1127,3874,3472],{"class":1140},[1127,3876,1752],{"class":1144},[1127,3878,3879],{"class":2216},"log_event",[1127,3881,3882],{"class":1144},"(\n",[1127,3884,3885,3887,3890,3892],{"class":1129,"line":2099},[1127,3886,1225],{"class":1154},[1127,3888,3889],{"class":1158},"http_request",[1127,3891,1162],{"class":1154},[1127,3893,1172],{"class":1144},[1127,3895,3896,3899,3901,3903,3905,3908],{"class":1129,"line":2118},[1127,3897,3898],{"class":3383},"            method",[1127,3900,3057],{"class":1144},[1127,3902,3093],{"class":2216},[1127,3904,1752],{"class":1144},[1127,3906,3907],{"class":2210},"method",[1127,3909,1172],{"class":1144},[1127,3911,3912,3915,3917,3919,3921,3923],{"class":1129,"line":2137},[1127,3913,3914],{"class":3383},"            path",[1127,3916,3057],{"class":1144},[1127,3918,3093],{"class":2216},[1127,3920,1752],{"class":1144},[1127,3922,2211],{"class":2210},[1127,3924,1172],{"class":1144},[1127,3926,3927,3930,3932,3935,3937,3939,3941,3944],{"class":1129,"line":2142},[1127,3928,3929],{"class":3383},"            user",[1127,3931,3057],{"class":1144},[1127,3933,3934],{"class":3307},"str",[1127,3936,2220],{"class":1144},[1127,3938,3093],{"class":2216},[1127,3940,1752],{"class":1144},[1127,3942,3943],{"class":2210},"user",[1127,3945,2244],{"class":1144},[1127,3947,3948,3951,3953,3955,3957,3960,3962,3964],{"class":1129,"line":2155},[1127,3949,3950],{"class":3383},"            ip_address",[1127,3952,3057],{"class":1144},[1127,3954,3460],{"class":1140},[1127,3956,1752],{"class":1144},[1127,3958,3959],{"class":2216},"get_client_ip",[1127,3961,2220],{"class":1144},[1127,3963,3093],{"class":2216},[1127,3965,2244],{"class":1144},[1127,3967,3968,3971,3973,3976],{"class":1129,"line":2174},[1127,3969,3970],{"class":3383},"            response_time",[1127,3972,3057],{"class":1144},[1127,3974,3975],{"class":2216},"response_time",[1127,3977,1172],{"class":1144},[1127,3979,3980,3983,3985],{"class":1129,"line":2194},[1127,3981,3982],{"class":3383},"            status_code",[1127,3984,3057],{"class":1144},[1127,3986,3987],{"class":2216},"status_code\n",[1127,3989,3990],{"class":1129,"line":2247},[1127,3991,3992],{"class":1144},"        )\n",[1127,3994,3995],{"class":1129,"line":2278},[1127,3996,3202],{"class":1654},[1127,3998,3999,4002],{"class":1129,"line":2295},[1127,4000,4001],{"class":1144},"    @",[1127,4003,4004],{"class":3307},"staticmethod\n",[1127,4006,4007,4009,4012,4014,4016],{"class":1129,"line":2314},[1127,4008,3450],{"class":1251},[1127,4010,4011],{"class":3086}," get_client_ip",[1127,4013,2220],{"class":1144},[1127,4015,3093],{"class":3092},[1127,4017,3096],{"class":1144},[1127,4019,4020,4023,4025,4027,4029,4033,4035,4038,4040,4042,4045,4047],{"class":1129,"line":2319},[1127,4021,4022],{"class":1654},"        x_forwarded_for ",[1127,4024,3057],{"class":1144},[1127,4026,3840],{"class":1654},[1127,4028,1752],{"class":1144},[1127,4030,4032],{"class":4031},"sFGJz","META",[1127,4034,1752],{"class":1144},[1127,4036,4037],{"class":2216},"get",[1127,4039,2220],{"class":1144},[1127,4041,1162],{"class":1154},[1127,4043,4044],{"class":1158},"HTTP_X_FORWARDED_FOR",[1127,4046,1162],{"class":1154},[1127,4048,3074],{"class":1144},[1127,4050,4051,4053,4056],{"class":1129,"line":2333},[1127,4052,3649],{"class":1650},[1127,4054,4055],{"class":1654}," x_forwarded_for",[1127,4057,3210],{"class":1144},[1127,4059,4060,4063,4065,4067,4069,4072,4074,4076,4078,4080,4083,4086],{"class":1129,"line":2353},[1127,4061,4062],{"class":1654},"            ip ",[1127,4064,3057],{"class":1144},[1127,4066,4055],{"class":1654},[1127,4068,1752],{"class":1144},[1127,4070,4071],{"class":2216},"split",[1127,4073,2220],{"class":1144},[1127,4075,1162],{"class":1154},[1127,4077,1569],{"class":1158},[1127,4079,1162],{"class":1154},[1127,4081,4082],{"class":1144},")[",[1127,4084,4085],{"class":1168},"0",[1127,4087,4088],{"class":1144},"]\n",[1127,4090,4091,4094],{"class":1129,"line":2372},[1127,4092,4093],{"class":1650},"        else",[1127,4095,3210],{"class":1144},[1127,4097,4098,4100,4102,4104,4106,4108,4110,4112,4114,4116,4119,4121],{"class":1129,"line":2416},[1127,4099,4062],{"class":1654},[1127,4101,3057],{"class":1144},[1127,4103,3840],{"class":1654},[1127,4105,1752],{"class":1144},[1127,4107,4032],{"class":4031},[1127,4109,1752],{"class":1144},[1127,4111,4037],{"class":2216},[1127,4113,2220],{"class":1144},[1127,4115,1162],{"class":1154},[1127,4117,4118],{"class":1158},"REMOTE_ADDR",[1127,4120,1162],{"class":1154},[1127,4122,3074],{"class":1144},[1127,4124,4125,4127],{"class":1129,"line":2441},[1127,4126,3261],{"class":1650},[1127,4128,4129],{"class":1654}," ip\n",[1127,4131,4132],{"class":1129,"line":2456},[1127,4133,1661],{"emptyLinePlaceholder":1660},[1127,4135,4136],{"class":1129,"line":2475},[1127,4137,4138],{"class":1133},"# Usage\n",[1127,4140,4141,4143,4145,4147,4149,4151],{"class":1129,"line":2480},[1127,4142,3054],{"class":1654},[1127,4144,3057],{"class":1144},[1127,4146,3443],{"class":2216},[1127,4148,2220],{"class":1144},[1127,4150,3071],{"class":3070},[1127,4152,3074],{"class":1144},[1127,4154,4155],{"class":1129,"line":2494},[1127,4156,1661],{"emptyLinePlaceholder":1660},[1127,4158,4159,4161,4163,4165,4167],{"class":1129,"line":2513},[1127,4160,3083],{"class":1251},[1127,4162,3087],{"class":3086},[1127,4164,2220],{"class":1144},[1127,4166,3093],{"class":3092},[1127,4168,3096],{"class":1144},[1127,4170,4171,4174,4176,4179,4181,4184],{"class":1129,"line":2534},[1127,4172,4173],{"class":1654},"    start_time ",[1127,4175,3057],{"class":1144},[1127,4177,4178],{"class":1654}," time",[1127,4180,1752],{"class":1144},[1127,4182,4183],{"class":2216},"time",[1127,4185,3228],{"class":1144},[1127,4187,4188],{"class":1129,"line":2554},[1127,4189,3202],{"class":1654},[1127,4191,4192,4194],{"class":1129,"line":2570},[1127,4193,3207],{"class":1650},[1127,4195,3210],{"class":1144},[1127,4197,4198],{"class":1129,"line":2575},[1127,4199,4200],{"class":1133},"        # Process request\n",[1127,4202,4203,4205,4207,4210,4212,4214],{"class":1129,"line":2580},[1127,4204,3220],{"class":1654},[1127,4206,3057],{"class":1144},[1127,4208,4209],{"class":2216}," process_request",[1127,4211,2220],{"class":1144},[1127,4213,3093],{"class":2216},[1127,4215,3074],{"class":1144},[1127,4217,4218],{"class":1129,"line":2593},[1127,4219,3618],{"class":1654},[1127,4221,4222,4225,4227,4229,4231,4233,4235,4238],{"class":1129,"line":2606},[1127,4223,4224],{"class":1654},"        response_time ",[1127,4226,3057],{"class":1144},[1127,4228,4178],{"class":1654},[1127,4230,1752],{"class":1144},[1127,4232,4183],{"class":2216},[1127,4234,1896],{"class":1144},[1127,4236,4237],{"class":2262}," -",[1127,4239,4240],{"class":1654}," start_time\n",[1127,4242,4243,4245,4247,4250,4252,4254,4256,4258,4260,4262,4264,4266,4268,4271],{"class":1129,"line":2635},[1127,4244,3233],{"class":1654},[1127,4246,1752],{"class":1144},[1127,4248,4249],{"class":2216},"log_request",[1127,4251,2220],{"class":1144},[1127,4253,3093],{"class":2216},[1127,4255,1569],{"class":1144},[1127,4257,3845],{"class":3383},[1127,4259,3057],{"class":1144},[1127,4261,3975],{"class":2216},[1127,4263,1569],{"class":1144},[1127,4265,3855],{"class":3383},[1127,4267,3057],{"class":1144},[1127,4269,4270],{"class":1168},"200",[1127,4272,3074],{"class":1144},[1127,4274,4275],{"class":1129,"line":2654},[1127,4276,3618],{"class":1654},[1127,4278,4279,4281,4283,4285,4287],{"class":1129,"line":2669},[1127,4280,3261],{"class":1650},[1127,4282,3264],{"class":2216},[1127,4284,2220],{"class":1144},[1127,4286,3250],{"class":2216},[1127,4288,3074],{"class":1144},[1127,4290,4291,4293,4295,4297,4299],{"class":1129,"line":2674},[1127,4292,3304],{"class":1650},[1127,4294,3308],{"class":3307},[1127,4296,3311],{"class":1650},[1127,4298,3314],{"class":1654},[1127,4300,3210],{"class":1144},[1127,4302,4303,4305,4307,4309,4311,4313,4315,4317],{"class":1129,"line":2687},[1127,4304,4224],{"class":1654},[1127,4306,3057],{"class":1144},[1127,4308,4178],{"class":1654},[1127,4310,1752],{"class":1144},[1127,4312,4183],{"class":2216},[1127,4314,1896],{"class":1144},[1127,4316,4237],{"class":2262},[1127,4318,4240],{"class":1654},[1127,4320,4321,4323,4325,4327,4329,4331,4334,4336,4338,4340,4342,4344,4346,4348],{"class":1129,"line":2716},[1127,4322,3233],{"class":1654},[1127,4324,1752],{"class":1144},[1127,4326,3879],{"class":2216},[1127,4328,2220],{"class":1144},[1127,4330,1162],{"class":1154},[1127,4332,4333],{"class":1158},"request_error",[1127,4335,1162],{"class":1154},[1127,4337,1569],{"class":1144},[1127,4339,3517],{"class":3383},[1127,4341,3057],{"class":1144},[1127,4343,1162],{"class":1154},[1127,4345,3166],{"class":1158},[1127,4347,1162],{"class":1154},[1127,4349,1172],{"class":1144},[1127,4351,4352,4355,4357,4359,4361,4363],{"class":1129,"line":2735},[1127,4353,4354],{"class":3383},"                        error",[1127,4356,3057],{"class":1144},[1127,4358,3934],{"class":3307},[1127,4360,2220],{"class":1144},[1127,4362,3377],{"class":2216},[1127,4364,2244],{"class":1144},[1127,4366,4367,4370,4372,4374,4376,4378],{"class":1129,"line":2750},[1127,4368,4369],{"class":3383},"                        path",[1127,4371,3057],{"class":1144},[1127,4373,3093],{"class":2216},[1127,4375,1752],{"class":1144},[1127,4377,2211],{"class":2210},[1127,4379,1172],{"class":1144},[1127,4381,4382,4385,4387,4389],{"class":1129,"line":2755},[1127,4383,4384],{"class":3383},"                        response_time",[1127,4386,3057],{"class":1144},[1127,4388,3975],{"class":2216},[1127,4390,3074],{"class":1144},[1127,4392,4393,4395,4397,4399,4401,4403,4405,4407,4409,4411,4413,4415,4417,4419,4421],{"class":1129,"line":2768},[1127,4394,3261],{"class":1650},[1127,4396,3264],{"class":2216},[1127,4398,3267],{"class":1144},[1127,4400,1162],{"class":1154},[1127,4402,3166],{"class":1158},[1127,4404,1162],{"class":1154},[1127,4406,1165],{"class":1144},[1127,4408,3372],{"class":3307},[1127,4410,2220],{"class":1144},[1127,4412,3377],{"class":2216},[1127,4414,3380],{"class":1144},[1127,4416,3384],{"class":3383},[1127,4418,3057],{"class":1144},[1127,4420,3389],{"class":1168},[1127,4422,3074],{"class":1144},[1038,4424,4426],{"id":4425},"context-logging","Context Logging",[1118,4428,4430],{"className":1120,"code":4429,"language":1122,"meta":1123,"style":1123},"# middleware.py\nimport logging\nimport uuid\nfrom django.utils.deprecation import MiddlewareMixin\n\nlogger = logging.getLogger(__name__)\n\nclass RequestLoggingMiddleware(MiddlewareMixin):\n    def process_request(self, request):\n        # Generate unique request ID\n        request.id = str(uuid.uuid4())\n        request.start_time = time.time()\n        \n        logger.info(\n            f'Request started',\n            extra={\n                'request_id': request.id,\n                'method': request.method,\n                'path': request.path,\n                'user': str(request.user),\n                'ip': self.get_client_ip(request)\n            }\n        )\n    \n    def process_response(self, request, response):\n        if hasattr(request, 'start_time'):\n            duration = time.time() - request.start_time\n            \n            logger.info(\n                f'Request completed',\n                extra={\n                    'request_id': getattr(request, 'id', 'unknown'),\n                    'method': request.method,\n                    'path': request.path,\n                    'status_code': response.status_code,\n                    'duration': f'{duration:.3f}s'\n                }\n            )\n        \n        return response\n    \n    def process_exception(self, request, exception):\n        logger.error(\n            f'Request failed with exception',\n            extra={\n                'request_id': getattr(request, 'id', 'unknown'),\n                'method': request.method,\n                'path': request.path,\n                'exception': str(exception)\n            },\n            exc_info=True\n        )\n    \n    @staticmethod\n    def get_client_ip(request):\n        x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')\n        if x_forwarded_for:\n            ip = x_forwarded_for.split(',')[0]\n        else:\n            ip = request.META.get('REMOTE_ADDR')\n        return ip\n",[1075,4431,4432,4437,4443,4450,4472,4476,4494,4498,4513,4529,4534,4561,4580,4584,4594,4604,4612,4632,4650,4668,4690,4714,4719,4723,4727,4749,4770,4794,4799,4810,4820,4827,4864,4882,4900,4919,4947,4952,4957,4961,4968,4972,4994,5004,5013,5019,5053,5071,5089,5107,5112,5122,5126,5130,5136,5148,5174,5182,5208,5214,5240],{"__ignoreMap":1123},[1127,4433,4434],{"class":1129,"line":1130},[1127,4435,4436],{"class":1133},"# middleware.py\n",[1127,4438,4439,4441],{"class":1129,"line":1137},[1127,4440,1651],{"class":1650},[1127,4442,3045],{"class":1654},[1127,4444,4445,4447],{"class":1129,"line":1151},[1127,4446,1651],{"class":1650},[1127,4448,4449],{"class":1654}," uuid\n",[1127,4451,4452,4454,4457,4459,4462,4464,4467,4469],{"class":1129,"line":1175},[1127,4453,3423],{"class":1650},[1127,4455,4456],{"class":1654}," django",[1127,4458,1752],{"class":1144},[1127,4460,4461],{"class":1654},"utils",[1127,4463,1752],{"class":1144},[1127,4465,4466],{"class":1654},"deprecation ",[1127,4468,1651],{"class":1650},[1127,4470,4471],{"class":1654}," MiddlewareMixin\n",[1127,4473,4474],{"class":1129,"line":1193},[1127,4475,1661],{"emptyLinePlaceholder":1660},[1127,4477,4478,4480,4482,4484,4486,4488,4490,4492],{"class":1129,"line":1207},[1127,4479,3054],{"class":1654},[1127,4481,3057],{"class":1144},[1127,4483,3060],{"class":1654},[1127,4485,1752],{"class":1144},[1127,4487,3065],{"class":2216},[1127,4489,2220],{"class":1144},[1127,4491,3071],{"class":3070},[1127,4493,3074],{"class":1144},[1127,4495,4496],{"class":1129,"line":1222},[1127,4497,1661],{"emptyLinePlaceholder":1660},[1127,4499,4500,4502,4505,4507,4511],{"class":1129,"line":1272},[1127,4501,1397],{"class":1251},[1127,4503,4504],{"class":3442}," RequestLoggingMiddleware",[1127,4506,2220],{"class":1144},[1127,4508,4510],{"class":4509},"sYn-s","MiddlewareMixin",[1127,4512,3096],{"class":1144},[1127,4514,4515,4517,4519,4521,4523,4525,4527],{"class":1129,"line":1293},[1127,4516,3450],{"class":1251},[1127,4518,4209],{"class":3086},[1127,4520,2220],{"class":1144},[1127,4522,3460],{"class":3459},[1127,4524,1569],{"class":1144},[1127,4526,3840],{"class":3092},[1127,4528,3096],{"class":1144},[1127,4530,4531],{"class":1129,"line":1299},[1127,4532,4533],{"class":1133},"        # Generate unique request ID\n",[1127,4535,4536,4539,4541,4544,4546,4548,4550,4553,4555,4558],{"class":1129,"line":1313},[1127,4537,4538],{"class":1654},"        request",[1127,4540,1752],{"class":1144},[1127,4542,4543],{"class":2210},"id",[1127,4545,1145],{"class":1144},[1127,4547,3372],{"class":3307},[1127,4549,2220],{"class":1144},[1127,4551,4552],{"class":2216},"uuid",[1127,4554,1752],{"class":1144},[1127,4556,4557],{"class":2216},"uuid4",[1127,4559,4560],{"class":1144},"())\n",[1127,4562,4563,4565,4567,4570,4572,4574,4576,4578],{"class":1129,"line":1334},[1127,4564,4538],{"class":1654},[1127,4566,1752],{"class":1144},[1127,4568,4569],{"class":2210},"start_time",[1127,4571,1145],{"class":1144},[1127,4573,4178],{"class":1654},[1127,4575,1752],{"class":1144},[1127,4577,4183],{"class":2216},[1127,4579,3228],{"class":1144},[1127,4581,4582],{"class":1129,"line":1353},[1127,4583,3618],{"class":1654},[1127,4585,4586,4588,4590,4592],{"class":1129,"line":1358},[1127,4587,3233],{"class":1654},[1127,4589,1752],{"class":1144},[1127,4591,3126],{"class":2216},[1127,4593,3882],{"class":1144},[1127,4595,4596,4599,4602],{"class":1129,"line":1364},[1127,4597,4598],{"class":1251},"            f",[1127,4600,4601],{"class":1158},"'Request started'",[1127,4603,1172],{"class":1144},[1127,4605,4606,4609],{"class":1129,"line":1378},[1127,4607,4608],{"class":3383},"            extra",[1127,4610,4611],{"class":1144},"={\n",[1127,4613,4614,4617,4620,4622,4624,4626,4628,4630],{"class":1129,"line":1392},[1127,4615,4616],{"class":1154},"                '",[1127,4618,4619],{"class":1158},"request_id",[1127,4621,1162],{"class":1154},[1127,4623,1165],{"class":1144},[1127,4625,3840],{"class":2216},[1127,4627,1752],{"class":1144},[1127,4629,4543],{"class":2210},[1127,4631,1172],{"class":1144},[1127,4633,4634,4636,4638,4640,4642,4644,4646,4648],{"class":1129,"line":1413},[1127,4635,4616],{"class":1154},[1127,4637,3907],{"class":1158},[1127,4639,1162],{"class":1154},[1127,4641,1165],{"class":1144},[1127,4643,3840],{"class":2216},[1127,4645,1752],{"class":1144},[1127,4647,3907],{"class":2210},[1127,4649,1172],{"class":1144},[1127,4651,4652,4654,4656,4658,4660,4662,4664,4666],{"class":1129,"line":1433},[1127,4653,4616],{"class":1154},[1127,4655,2211],{"class":1158},[1127,4657,1162],{"class":1154},[1127,4659,1165],{"class":1144},[1127,4661,3840],{"class":2216},[1127,4663,1752],{"class":1144},[1127,4665,2211],{"class":2210},[1127,4667,1172],{"class":1144},[1127,4669,4670,4672,4674,4676,4678,4680,4682,4684,4686,4688],{"class":1129,"line":1438},[1127,4671,4616],{"class":1154},[1127,4673,3943],{"class":1158},[1127,4675,1162],{"class":1154},[1127,4677,1165],{"class":1144},[1127,4679,3372],{"class":3307},[1127,4681,2220],{"class":1144},[1127,4683,3093],{"class":2216},[1127,4685,1752],{"class":1144},[1127,4687,3943],{"class":2210},[1127,4689,2244],{"class":1144},[1127,4691,4692,4694,4697,4699,4701,4704,4706,4708,4710,4712],{"class":1129,"line":1452},[1127,4693,4616],{"class":1154},[1127,4695,4696],{"class":1158},"ip",[1127,4698,1162],{"class":1154},[1127,4700,1165],{"class":1144},[1127,4702,4703],{"class":1140}," self",[1127,4705,1752],{"class":1144},[1127,4707,3959],{"class":2216},[1127,4709,2220],{"class":1144},[1127,4711,3093],{"class":2216},[1127,4713,3074],{"class":1144},[1127,4715,4716],{"class":1129,"line":1472},[1127,4717,4718],{"class":1144},"            }\n",[1127,4720,4721],{"class":1129,"line":1493},[1127,4722,3992],{"class":1144},[1127,4724,4725],{"class":1129,"line":1512},[1127,4726,3202],{"class":1654},[1127,4728,4729,4731,4734,4736,4738,4740,4742,4744,4747],{"class":1129,"line":1517},[1127,4730,3450],{"class":1251},[1127,4732,4733],{"class":3086}," process_response",[1127,4735,2220],{"class":1144},[1127,4737,3460],{"class":3459},[1127,4739,1569],{"class":1144},[1127,4741,3840],{"class":3092},[1127,4743,1569],{"class":1144},[1127,4745,4746],{"class":3092}," response",[1127,4748,3096],{"class":1144},[1127,4750,4751,4753,4756,4758,4760,4762,4764,4766,4768],{"class":1129,"line":1522},[1127,4752,3649],{"class":1650},[1127,4754,4755],{"class":3453}," hasattr",[1127,4757,2220],{"class":1144},[1127,4759,3093],{"class":2216},[1127,4761,1569],{"class":1144},[1127,4763,1235],{"class":1154},[1127,4765,4569],{"class":1158},[1127,4767,1162],{"class":1154},[1127,4769,3096],{"class":1144},[1127,4771,4772,4775,4777,4779,4781,4783,4785,4787,4789,4791],{"class":1129,"line":1536},[1127,4773,4774],{"class":1654},"            duration ",[1127,4776,3057],{"class":1144},[1127,4778,4178],{"class":1654},[1127,4780,1752],{"class":1144},[1127,4782,4183],{"class":2216},[1127,4784,1896],{"class":1144},[1127,4786,4237],{"class":2262},[1127,4788,3840],{"class":1654},[1127,4790,1752],{"class":1144},[1127,4792,4793],{"class":2210},"start_time\n",[1127,4795,4796],{"class":1129,"line":1549},[1127,4797,4798],{"class":1654},"            \n",[1127,4800,4801,4804,4806,4808],{"class":1129,"line":1581},[1127,4802,4803],{"class":1654},"            logger",[1127,4805,1752],{"class":1144},[1127,4807,3126],{"class":2216},[1127,4809,3882],{"class":1144},[1127,4811,4812,4815,4818],{"class":1129,"line":1602},[1127,4813,4814],{"class":1251},"                f",[1127,4816,4817],{"class":1158},"'Request completed'",[1127,4819,1172],{"class":1144},[1127,4821,4822,4825],{"class":1129,"line":1619},[1127,4823,4824],{"class":3383},"                extra",[1127,4826,4611],{"class":1144},[1127,4828,4829,4832,4834,4836,4838,4841,4843,4845,4847,4849,4851,4853,4855,4857,4860,4862],{"class":1129,"line":1624},[1127,4830,4831],{"class":1154},"                    '",[1127,4833,4619],{"class":1158},[1127,4835,1162],{"class":1154},[1127,4837,1165],{"class":1144},[1127,4839,4840],{"class":3453}," getattr",[1127,4842,2220],{"class":1144},[1127,4844,3093],{"class":2216},[1127,4846,1569],{"class":1144},[1127,4848,1235],{"class":1154},[1127,4850,4543],{"class":1158},[1127,4852,1162],{"class":1154},[1127,4854,1569],{"class":1144},[1127,4856,1235],{"class":1154},[1127,4858,4859],{"class":1158},"unknown",[1127,4861,1162],{"class":1154},[1127,4863,2244],{"class":1144},[1127,4865,4866,4868,4870,4872,4874,4876,4878,4880],{"class":1129,"line":1629},[1127,4867,4831],{"class":1154},[1127,4869,3907],{"class":1158},[1127,4871,1162],{"class":1154},[1127,4873,1165],{"class":1144},[1127,4875,3840],{"class":2216},[1127,4877,1752],{"class":1144},[1127,4879,3907],{"class":2210},[1127,4881,1172],{"class":1144},[1127,4883,4884,4886,4888,4890,4892,4894,4896,4898],{"class":1129,"line":2099},[1127,4885,4831],{"class":1154},[1127,4887,2211],{"class":1158},[1127,4889,1162],{"class":1154},[1127,4891,1165],{"class":1144},[1127,4893,3840],{"class":2216},[1127,4895,1752],{"class":1144},[1127,4897,2211],{"class":2210},[1127,4899,1172],{"class":1144},[1127,4901,4902,4904,4907,4909,4911,4913,4915,4917],{"class":1129,"line":2118},[1127,4903,4831],{"class":1154},[1127,4905,4906],{"class":1158},"status_code",[1127,4908,1162],{"class":1154},[1127,4910,1165],{"class":1144},[1127,4912,4746],{"class":2216},[1127,4914,1752],{"class":1144},[1127,4916,4906],{"class":2210},[1127,4918,1172],{"class":1144},[1127,4920,4921,4923,4926,4928,4930,4933,4935,4937,4939,4942,4944],{"class":1129,"line":2137},[1127,4922,4831],{"class":1154},[1127,4924,4925],{"class":1158},"duration",[1127,4927,1162],{"class":1154},[1127,4929,1165],{"class":1144},[1127,4931,4932],{"class":1251}," f",[1127,4934,1162],{"class":1158},[1127,4936,1286],{"class":1238},[1127,4938,4925],{"class":2216},[1127,4940,4941],{"class":1251},":.3f",[1127,4943,1255],{"class":1238},[1127,4945,4946],{"class":1158},"s'\n",[1127,4948,4949],{"class":1129,"line":2142},[1127,4950,4951],{"class":1144},"                }\n",[1127,4953,4954],{"class":1129,"line":2155},[1127,4955,4956],{"class":1144},"            )\n",[1127,4958,4959],{"class":1129,"line":2174},[1127,4960,3618],{"class":1654},[1127,4962,4963,4965],{"class":1129,"line":2194},[1127,4964,3261],{"class":1650},[1127,4966,4967],{"class":1654}," response\n",[1127,4969,4970],{"class":1129,"line":2247},[1127,4971,3202],{"class":1654},[1127,4973,4974,4976,4979,4981,4983,4985,4987,4989,4992],{"class":1129,"line":2278},[1127,4975,3450],{"class":1251},[1127,4977,4978],{"class":3086}," process_exception",[1127,4980,2220],{"class":1144},[1127,4982,3460],{"class":3459},[1127,4984,1569],{"class":1144},[1127,4986,3840],{"class":3092},[1127,4988,1569],{"class":1144},[1127,4990,4991],{"class":3092}," exception",[1127,4993,3096],{"class":1144},[1127,4995,4996,4998,5000,5002],{"class":1129,"line":2295},[1127,4997,3233],{"class":1654},[1127,4999,1752],{"class":1144},[1127,5001,3166],{"class":2216},[1127,5003,3882],{"class":1144},[1127,5005,5006,5008,5011],{"class":1129,"line":2314},[1127,5007,4598],{"class":1251},[1127,5009,5010],{"class":1158},"'Request failed with exception'",[1127,5012,1172],{"class":1144},[1127,5014,5015,5017],{"class":1129,"line":2319},[1127,5016,4608],{"class":3383},[1127,5018,4611],{"class":1144},[1127,5020,5021,5023,5025,5027,5029,5031,5033,5035,5037,5039,5041,5043,5045,5047,5049,5051],{"class":1129,"line":2333},[1127,5022,4616],{"class":1154},[1127,5024,4619],{"class":1158},[1127,5026,1162],{"class":1154},[1127,5028,1165],{"class":1144},[1127,5030,4840],{"class":3453},[1127,5032,2220],{"class":1144},[1127,5034,3093],{"class":2216},[1127,5036,1569],{"class":1144},[1127,5038,1235],{"class":1154},[1127,5040,4543],{"class":1158},[1127,5042,1162],{"class":1154},[1127,5044,1569],{"class":1144},[1127,5046,1235],{"class":1154},[1127,5048,4859],{"class":1158},[1127,5050,1162],{"class":1154},[1127,5052,2244],{"class":1144},[1127,5054,5055,5057,5059,5061,5063,5065,5067,5069],{"class":1129,"line":2353},[1127,5056,4616],{"class":1154},[1127,5058,3907],{"class":1158},[1127,5060,1162],{"class":1154},[1127,5062,1165],{"class":1144},[1127,5064,3840],{"class":2216},[1127,5066,1752],{"class":1144},[1127,5068,3907],{"class":2210},[1127,5070,1172],{"class":1144},[1127,5072,5073,5075,5077,5079,5081,5083,5085,5087],{"class":1129,"line":2372},[1127,5074,4616],{"class":1154},[1127,5076,2211],{"class":1158},[1127,5078,1162],{"class":1154},[1127,5080,1165],{"class":1144},[1127,5082,3840],{"class":2216},[1127,5084,1752],{"class":1144},[1127,5086,2211],{"class":2210},[1127,5088,1172],{"class":1144},[1127,5090,5091,5093,5095,5097,5099,5101,5103,5105],{"class":1129,"line":2416},[1127,5092,4616],{"class":1154},[1127,5094,3325],{"class":1158},[1127,5096,1162],{"class":1154},[1127,5098,1165],{"class":1144},[1127,5100,3372],{"class":3307},[1127,5102,2220],{"class":1144},[1127,5104,3325],{"class":2216},[1127,5106,3074],{"class":1144},[1127,5108,5109],{"class":1129,"line":2441},[1127,5110,5111],{"class":1144},"            },\n",[1127,5113,5114,5117,5119],{"class":1129,"line":2456},[1127,5115,5116],{"class":3383},"            exc_info",[1127,5118,3057],{"class":1144},[1127,5120,5121],{"class":1187},"True\n",[1127,5123,5124],{"class":1129,"line":2475},[1127,5125,3992],{"class":1144},[1127,5127,5128],{"class":1129,"line":2480},[1127,5129,3202],{"class":1654},[1127,5131,5132,5134],{"class":1129,"line":2494},[1127,5133,4001],{"class":1144},[1127,5135,4004],{"class":3307},[1127,5137,5138,5140,5142,5144,5146],{"class":1129,"line":2513},[1127,5139,3450],{"class":1251},[1127,5141,4011],{"class":3086},[1127,5143,2220],{"class":1144},[1127,5145,3093],{"class":3092},[1127,5147,3096],{"class":1144},[1127,5149,5150,5152,5154,5156,5158,5160,5162,5164,5166,5168,5170,5172],{"class":1129,"line":2534},[1127,5151,4022],{"class":1654},[1127,5153,3057],{"class":1144},[1127,5155,3840],{"class":1654},[1127,5157,1752],{"class":1144},[1127,5159,4032],{"class":4031},[1127,5161,1752],{"class":1144},[1127,5163,4037],{"class":2216},[1127,5165,2220],{"class":1144},[1127,5167,1162],{"class":1154},[1127,5169,4044],{"class":1158},[1127,5171,1162],{"class":1154},[1127,5173,3074],{"class":1144},[1127,5175,5176,5178,5180],{"class":1129,"line":2554},[1127,5177,3649],{"class":1650},[1127,5179,4055],{"class":1654},[1127,5181,3210],{"class":1144},[1127,5183,5184,5186,5188,5190,5192,5194,5196,5198,5200,5202,5204,5206],{"class":1129,"line":2570},[1127,5185,4062],{"class":1654},[1127,5187,3057],{"class":1144},[1127,5189,4055],{"class":1654},[1127,5191,1752],{"class":1144},[1127,5193,4071],{"class":2216},[1127,5195,2220],{"class":1144},[1127,5197,1162],{"class":1154},[1127,5199,1569],{"class":1158},[1127,5201,1162],{"class":1154},[1127,5203,4082],{"class":1144},[1127,5205,4085],{"class":1168},[1127,5207,4088],{"class":1144},[1127,5209,5210,5212],{"class":1129,"line":2575},[1127,5211,4093],{"class":1650},[1127,5213,3210],{"class":1144},[1127,5215,5216,5218,5220,5222,5224,5226,5228,5230,5232,5234,5236,5238],{"class":1129,"line":2580},[1127,5217,4062],{"class":1654},[1127,5219,3057],{"class":1144},[1127,5221,3840],{"class":1654},[1127,5223,1752],{"class":1144},[1127,5225,4032],{"class":4031},[1127,5227,1752],{"class":1144},[1127,5229,4037],{"class":2216},[1127,5231,2220],{"class":1144},[1127,5233,1162],{"class":1154},[1127,5235,4118],{"class":1158},[1127,5237,1162],{"class":1154},[1127,5239,3074],{"class":1144},[1127,5241,5242,5244],{"class":1129,"line":2593},[1127,5243,3261],{"class":1650},[1127,5245,4129],{"class":1654},[1030,5247,5249],{"id":5248},"advanced-logging-patterns","Advanced Logging Patterns",[1038,5251,5253],{"id":5252},"database-query-logging","Database Query Logging",[1118,5255,5257],{"className":1120,"code":5256,"language":1122,"meta":1123,"style":1123},"# settings.py - Log all SQL queries in development\nif DEBUG:\n    LOGGING['loggers']['django.db.backends'] = {\n        'handlers': ['console'],\n        'level': 'DEBUG',\n        'propagate': False,\n    }\n\n# Custom query logger\nimport logging\nfrom django.db import connection\nfrom django.utils.deprecation import MiddlewareMixin\n\nlogger = logging.getLogger('sql_queries')\n\nclass QueryLoggingMiddleware(MiddlewareMixin):\n    def process_response(self, request, response):\n        if settings.DEBUG:\n            queries = connection.queries\n            total_time = sum(float(q['time']) for q in queries)\n            \n            logger.info(\n                f'SQL Queries: {len(queries)} queries, Total time: {total_time:.3f}s',\n                extra={\n                    'path': request.path,\n                    'query_count': len(queries),\n                    'total_time': total_time\n                }\n            )\n            \n            # Log slow queries\n            for query in queries:\n                if float(query['time']) > 0.1:  # Queries slower than 100ms\n                    logger.warning(\n                        f'Slow query detected: {query[\"time\"]}s',\n                        extra={'sql': query['sql'][:200]}\n                    )\n        \n        return response\n",[1075,5258,5259,5264,5273,5302,5322,5340,5354,5359,5363,5368,5374,5390,5408,5412,5435,5439,5452,5472,5485,5500,5545,5549,5559,5598,5604,5622,5642,5655,5659,5663,5667,5672,5686,5720,5731,5760,5796,5801,5805],{"__ignoreMap":1123},[1127,5260,5261],{"class":1129,"line":1130},[1127,5262,5263],{"class":1133},"# settings.py - Log all SQL queries in development\n",[1127,5265,5266,5269,5271],{"class":1129,"line":1137},[1127,5267,5268],{"class":1650},"if",[1127,5270,2810],{"class":1140},[1127,5272,3210],{"class":1144},[1127,5274,5275,5278,5280,5282,5284,5286,5289,5291,5293,5295,5298,5300],{"class":1129,"line":1151},[1127,5276,5277],{"class":1140},"    LOGGING",[1127,5279,1736],{"class":1144},[1127,5281,1162],{"class":1154},[1127,5283,1527],{"class":1158},[1127,5285,1162],{"class":1154},[1127,5287,5288],{"class":1144},"][",[1127,5290,1162],{"class":1154},[1127,5292,1101],{"class":1158},[1127,5294,1162],{"class":1154},[1127,5296,5297],{"class":1144},"]",[1127,5299,1145],{"class":1144},[1127,5301,1148],{"class":1144},[1127,5303,5304,5306,5308,5310,5312,5314,5316,5318,5320],{"class":1129,"line":1175},[1127,5305,1210],{"class":1154},[1127,5307,1369],{"class":1158},[1127,5309,1162],{"class":1154},[1127,5311,1165],{"class":1144},[1127,5313,1560],{"class":1144},[1127,5315,1162],{"class":1154},[1127,5317,1383],{"class":1158},[1127,5319,1162],{"class":1154},[1127,5321,1578],{"class":1144},[1127,5323,5324,5326,5328,5330,5332,5334,5336,5338],{"class":1129,"line":1193},[1127,5325,1210],{"class":1154},[1127,5327,1586],{"class":1158},[1127,5329,1162],{"class":1154},[1127,5331,1165],{"class":1144},[1127,5333,1235],{"class":1154},[1127,5335,2802],{"class":1158},[1127,5337,1162],{"class":1154},[1127,5339,1172],{"class":1144},[1127,5341,5342,5344,5346,5348,5350,5352],{"class":1129,"line":1207},[1127,5343,1210],{"class":1154},[1127,5345,1607],{"class":1158},[1127,5347,1162],{"class":1154},[1127,5349,1165],{"class":1144},[1127,5351,1188],{"class":1187},[1127,5353,1172],{"class":1144},[1127,5355,5356],{"class":1129,"line":1222},[1127,5357,5358],{"class":1144},"    }\n",[1127,5360,5361],{"class":1129,"line":1272},[1127,5362,1661],{"emptyLinePlaceholder":1660},[1127,5364,5365],{"class":1129,"line":1293},[1127,5366,5367],{"class":1133},"# Custom query logger\n",[1127,5369,5370,5372],{"class":1129,"line":1299},[1127,5371,1651],{"class":1650},[1127,5373,3045],{"class":1654},[1127,5375,5376,5378,5380,5382,5385,5387],{"class":1129,"line":1313},[1127,5377,3423],{"class":1650},[1127,5379,4456],{"class":1654},[1127,5381,1752],{"class":1144},[1127,5383,5384],{"class":1654},"db ",[1127,5386,1651],{"class":1650},[1127,5388,5389],{"class":1654}," connection\n",[1127,5391,5392,5394,5396,5398,5400,5402,5404,5406],{"class":1129,"line":1334},[1127,5393,3423],{"class":1650},[1127,5395,4456],{"class":1654},[1127,5397,1752],{"class":1144},[1127,5399,4461],{"class":1654},[1127,5401,1752],{"class":1144},[1127,5403,4466],{"class":1654},[1127,5405,1651],{"class":1650},[1127,5407,4471],{"class":1654},[1127,5409,5410],{"class":1129,"line":1353},[1127,5411,1661],{"emptyLinePlaceholder":1660},[1127,5413,5414,5416,5418,5420,5422,5424,5426,5428,5431,5433],{"class":1129,"line":1358},[1127,5415,3054],{"class":1654},[1127,5417,3057],{"class":1144},[1127,5419,3060],{"class":1654},[1127,5421,1752],{"class":1144},[1127,5423,3065],{"class":2216},[1127,5425,2220],{"class":1144},[1127,5427,1162],{"class":1154},[1127,5429,5430],{"class":1158},"sql_queries",[1127,5432,1162],{"class":1154},[1127,5434,3074],{"class":1144},[1127,5436,5437],{"class":1129,"line":1364},[1127,5438,1661],{"emptyLinePlaceholder":1660},[1127,5440,5441,5443,5446,5448,5450],{"class":1129,"line":1378},[1127,5442,1397],{"class":1251},[1127,5444,5445],{"class":3442}," QueryLoggingMiddleware",[1127,5447,2220],{"class":1144},[1127,5449,4510],{"class":4509},[1127,5451,3096],{"class":1144},[1127,5453,5454,5456,5458,5460,5462,5464,5466,5468,5470],{"class":1129,"line":1392},[1127,5455,3450],{"class":1251},[1127,5457,4733],{"class":3086},[1127,5459,2220],{"class":1144},[1127,5461,3460],{"class":3459},[1127,5463,1569],{"class":1144},[1127,5465,3840],{"class":3092},[1127,5467,1569],{"class":1144},[1127,5469,4746],{"class":3092},[1127,5471,3096],{"class":1144},[1127,5473,5474,5476,5479,5481,5483],{"class":1129,"line":1413},[1127,5475,3649],{"class":1650},[1127,5477,5478],{"class":1654}," settings",[1127,5480,1752],{"class":1144},[1127,5482,2802],{"class":4031},[1127,5484,3210],{"class":1144},[1127,5486,5487,5490,5492,5495,5497],{"class":1129,"line":1433},[1127,5488,5489],{"class":1654},"            queries ",[1127,5491,3057],{"class":1144},[1127,5493,5494],{"class":1654}," connection",[1127,5496,1752],{"class":1144},[1127,5498,5499],{"class":2210},"queries\n",[1127,5501,5502,5505,5507,5510,5512,5515,5517,5520,5522,5524,5526,5528,5531,5534,5537,5540,5543],{"class":1129,"line":1438},[1127,5503,5504],{"class":1654},"            total_time ",[1127,5506,3057],{"class":1144},[1127,5508,5509],{"class":3453}," sum",[1127,5511,2220],{"class":1144},[1127,5513,5514],{"class":3307},"float",[1127,5516,2220],{"class":1144},[1127,5518,5519],{"class":2216},"q",[1127,5521,1736],{"class":1144},[1127,5523,1162],{"class":1154},[1127,5525,4183],{"class":1158},[1127,5527,1162],{"class":1154},[1127,5529,5530],{"class":1144},"])",[1127,5532,5533],{"class":1650}," for",[1127,5535,5536],{"class":2216}," q ",[1127,5538,5539],{"class":1650},"in",[1127,5541,5542],{"class":2216}," queries",[1127,5544,3074],{"class":1144},[1127,5546,5547],{"class":1129,"line":1452},[1127,5548,4798],{"class":1654},[1127,5550,5551,5553,5555,5557],{"class":1129,"line":1472},[1127,5552,4803],{"class":1654},[1127,5554,1752],{"class":1144},[1127,5556,3126],{"class":2216},[1127,5558,3882],{"class":1144},[1127,5560,5561,5563,5566,5568,5571,5573,5576,5579,5581,5584,5586,5589,5591,5593,5596],{"class":1129,"line":1493},[1127,5562,4814],{"class":1251},[1127,5564,5565],{"class":1158},"'SQL Queries: ",[1127,5567,1286],{"class":1238},[1127,5569,5570],{"class":3453},"len",[1127,5572,2220],{"class":1144},[1127,5574,5575],{"class":2216},"queries",[1127,5577,5578],{"class":1144},")",[1127,5580,1255],{"class":1238},[1127,5582,5583],{"class":1158}," queries, Total time: ",[1127,5585,1286],{"class":1238},[1127,5587,5588],{"class":2216},"total_time",[1127,5590,4941],{"class":1251},[1127,5592,1255],{"class":1238},[1127,5594,5595],{"class":1158},"s'",[1127,5597,1172],{"class":1144},[1127,5599,5600,5602],{"class":1129,"line":1512},[1127,5601,4824],{"class":3383},[1127,5603,4611],{"class":1144},[1127,5605,5606,5608,5610,5612,5614,5616,5618,5620],{"class":1129,"line":1517},[1127,5607,4831],{"class":1154},[1127,5609,2211],{"class":1158},[1127,5611,1162],{"class":1154},[1127,5613,1165],{"class":1144},[1127,5615,3840],{"class":2216},[1127,5617,1752],{"class":1144},[1127,5619,2211],{"class":2210},[1127,5621,1172],{"class":1144},[1127,5623,5624,5626,5629,5631,5633,5636,5638,5640],{"class":1129,"line":1522},[1127,5625,4831],{"class":1154},[1127,5627,5628],{"class":1158},"query_count",[1127,5630,1162],{"class":1154},[1127,5632,1165],{"class":1144},[1127,5634,5635],{"class":3453}," len",[1127,5637,2220],{"class":1144},[1127,5639,5575],{"class":2216},[1127,5641,2244],{"class":1144},[1127,5643,5644,5646,5648,5650,5652],{"class":1129,"line":1536},[1127,5645,4831],{"class":1154},[1127,5647,5588],{"class":1158},[1127,5649,1162],{"class":1154},[1127,5651,1165],{"class":1144},[1127,5653,5654],{"class":2216}," total_time\n",[1127,5656,5657],{"class":1129,"line":1549},[1127,5658,4951],{"class":1144},[1127,5660,5661],{"class":1129,"line":1581},[1127,5662,4956],{"class":1144},[1127,5664,5665],{"class":1129,"line":1602},[1127,5666,4798],{"class":1654},[1127,5668,5669],{"class":1129,"line":1619},[1127,5670,5671],{"class":1133},"            # Log slow queries\n",[1127,5673,5674,5677,5680,5682,5684],{"class":1129,"line":1624},[1127,5675,5676],{"class":1650},"            for",[1127,5678,5679],{"class":1654}," query ",[1127,5681,5539],{"class":1650},[1127,5683,5542],{"class":1654},[1127,5685,3210],{"class":1144},[1127,5687,5688,5691,5694,5696,5699,5701,5703,5705,5707,5709,5712,5715,5717],{"class":1129,"line":1629},[1127,5689,5690],{"class":1650},"                if",[1127,5692,5693],{"class":3307}," float",[1127,5695,2220],{"class":1144},[1127,5697,5698],{"class":2216},"query",[1127,5700,1736],{"class":1144},[1127,5702,1162],{"class":1154},[1127,5704,4183],{"class":1158},[1127,5706,1162],{"class":1154},[1127,5708,5530],{"class":1144},[1127,5710,5711],{"class":2262}," >",[1127,5713,5714],{"class":1168}," 0.1",[1127,5716,1165],{"class":1144},[1127,5718,5719],{"class":1133},"  # Queries slower than 100ms\n",[1127,5721,5722,5725,5727,5729],{"class":1129,"line":2099},[1127,5723,5724],{"class":1654},"                    logger",[1127,5726,1752],{"class":1144},[1127,5728,3146],{"class":2216},[1127,5730,3882],{"class":1144},[1127,5732,5733,5736,5739,5741,5743,5745,5748,5750,5752,5754,5756,5758],{"class":1129,"line":2118},[1127,5734,5735],{"class":1251},"                        f",[1127,5737,5738],{"class":1158},"'Slow query detected: ",[1127,5740,1286],{"class":1238},[1127,5742,5698],{"class":2216},[1127,5744,1736],{"class":1144},[1127,5746,5747],{"class":1154},"\"",[1127,5749,4183],{"class":1158},[1127,5751,5747],{"class":1154},[1127,5753,5297],{"class":1144},[1127,5755,1255],{"class":1238},[1127,5757,5595],{"class":1158},[1127,5759,1172],{"class":1144},[1127,5761,5762,5765,5768,5770,5773,5775,5777,5780,5782,5784,5786,5788,5791,5793],{"class":1129,"line":2137},[1127,5763,5764],{"class":3383},"                        extra",[1127,5766,5767],{"class":1144},"={",[1127,5769,1162],{"class":1154},[1127,5771,5772],{"class":1158},"sql",[1127,5774,1162],{"class":1154},[1127,5776,1165],{"class":1144},[1127,5778,5779],{"class":2216}," query",[1127,5781,1736],{"class":1144},[1127,5783,1162],{"class":1154},[1127,5785,5772],{"class":1158},[1127,5787,1162],{"class":1154},[1127,5789,5790],{"class":1144},"][:",[1127,5792,4270],{"class":1168},[1127,5794,5795],{"class":1144},"]}\n",[1127,5797,5798],{"class":1129,"line":2142},[1127,5799,5800],{"class":1144},"                    )\n",[1127,5802,5803],{"class":1129,"line":2155},[1127,5804,3618],{"class":1654},[1127,5806,5807,5809],{"class":1129,"line":2174},[1127,5808,3261],{"class":1650},[1127,5810,4967],{"class":1654},[1038,5812,5814],{"id":5813},"performance-logging","Performance Logging",[1118,5816,5818],{"className":1120,"code":5817,"language":1122,"meta":1123,"style":1123},"# decorators.py\nimport logging\nimport time\nfrom functools import wraps\n\nlogger = logging.getLogger(__name__)\n\ndef log_performance(func):\n    \"\"\"Decorator to log function performance\"\"\"\n    @wraps(func)\n    def wrapper(*args, **kwargs):\n        start_time = time.time()\n        \n        try:\n            result = func(*args, **kwargs)\n            duration = time.time() - start_time\n            \n            logger.info(\n                f'{func.__name__} completed',\n                extra={\n                    'function': func.__name__,\n                    'duration': f'{duration:.3f}s',\n                    'status': 'success'\n                }\n            )\n            \n            return result\n        except Exception as e:\n            duration = time.time() - start_time\n            \n            logger.error(\n                f'{func.__name__} failed',\n                extra={\n                    'function': func.__name__,\n                    'duration': f'{duration:.3f}s',\n                    'status': 'error',\n                    'error': str(e)\n                },\n                exc_info=True\n            )\n            raise\n    \n    return wrapper\n\n# Usage\n@log_performance\ndef expensive_operation():\n    # Your code here\n    pass\n",[1075,5819,5820,5825,5831,5838,5850,5854,5872,5876,5890,5900,5913,5936,5951,5955,5962,5986,6004,6008,6018,6039,6045,6064,6090,6107,6111,6115,6119,6127,6140,6158,6162,6172,6193,6199,6217,6243,6261,6279,6284,6293,6297,6302,6306,6314,6318,6322,6330,6340,6345],{"__ignoreMap":1123},[1127,5821,5822],{"class":1129,"line":1130},[1127,5823,5824],{"class":1133},"# decorators.py\n",[1127,5826,5827,5829],{"class":1129,"line":1137},[1127,5828,1651],{"class":1650},[1127,5830,3045],{"class":1654},[1127,5832,5833,5835],{"class":1129,"line":1151},[1127,5834,1651],{"class":1650},[1127,5836,5837],{"class":1654}," time\n",[1127,5839,5840,5842,5845,5847],{"class":1129,"line":1175},[1127,5841,3423],{"class":1650},[1127,5843,5844],{"class":1654}," functools ",[1127,5846,1651],{"class":1650},[1127,5848,5849],{"class":1654}," wraps\n",[1127,5851,5852],{"class":1129,"line":1193},[1127,5853,1661],{"emptyLinePlaceholder":1660},[1127,5855,5856,5858,5860,5862,5864,5866,5868,5870],{"class":1129,"line":1207},[1127,5857,3054],{"class":1654},[1127,5859,3057],{"class":1144},[1127,5861,3060],{"class":1654},[1127,5863,1752],{"class":1144},[1127,5865,3065],{"class":2216},[1127,5867,2220],{"class":1144},[1127,5869,3071],{"class":3070},[1127,5871,3074],{"class":1144},[1127,5873,5874],{"class":1129,"line":1222},[1127,5875,1661],{"emptyLinePlaceholder":1660},[1127,5877,5878,5880,5883,5885,5888],{"class":1129,"line":1272},[1127,5879,3083],{"class":1251},[1127,5881,5882],{"class":3086}," log_performance",[1127,5884,2220],{"class":1144},[1127,5886,5887],{"class":3092},"func",[1127,5889,3096],{"class":1144},[1127,5891,5892,5895,5898],{"class":1129,"line":1293},[1127,5893,5894],{"class":3540},"    \"\"\"",[1127,5896,5897],{"class":3544},"Decorator to log function performance",[1127,5899,3548],{"class":3540},[1127,5901,5902,5904,5907,5909,5911],{"class":1129,"line":1299},[1127,5903,4001],{"class":1144},[1127,5905,5906],{"class":3086},"wraps",[1127,5908,2220],{"class":1144},[1127,5910,5887],{"class":2216},[1127,5912,3074],{"class":1144},[1127,5914,5915,5917,5920,5922,5925,5928,5930,5932,5934],{"class":1129,"line":1313},[1127,5916,3450],{"class":1251},[1127,5918,5919],{"class":3086}," wrapper",[1127,5921,2220],{"class":1144},[1127,5923,5924],{"class":2262},"*",[1127,5926,5927],{"class":3092},"args",[1127,5929,1569],{"class":1144},[1127,5931,3530],{"class":2262},[1127,5933,3533],{"class":3092},[1127,5935,3096],{"class":1144},[1127,5937,5938,5941,5943,5945,5947,5949],{"class":1129,"line":1334},[1127,5939,5940],{"class":1654},"        start_time ",[1127,5942,3057],{"class":1144},[1127,5944,4178],{"class":1654},[1127,5946,1752],{"class":1144},[1127,5948,4183],{"class":2216},[1127,5950,3228],{"class":1144},[1127,5952,5953],{"class":1129,"line":1353},[1127,5954,3618],{"class":1654},[1127,5956,5957,5960],{"class":1129,"line":1358},[1127,5958,5959],{"class":1650},"        try",[1127,5961,3210],{"class":1144},[1127,5963,5964,5967,5969,5972,5974,5976,5978,5980,5982,5984],{"class":1129,"line":1364},[1127,5965,5966],{"class":1654},"            result ",[1127,5968,3057],{"class":1144},[1127,5970,5971],{"class":2216}," func",[1127,5973,2220],{"class":1144},[1127,5975,5924],{"class":2262},[1127,5977,5927],{"class":2216},[1127,5979,1569],{"class":1144},[1127,5981,3530],{"class":2262},[1127,5983,3533],{"class":2216},[1127,5985,3074],{"class":1144},[1127,5987,5988,5990,5992,5994,5996,5998,6000,6002],{"class":1129,"line":1378},[1127,5989,4774],{"class":1654},[1127,5991,3057],{"class":1144},[1127,5993,4178],{"class":1654},[1127,5995,1752],{"class":1144},[1127,5997,4183],{"class":2216},[1127,5999,1896],{"class":1144},[1127,6001,4237],{"class":2262},[1127,6003,4240],{"class":1654},[1127,6005,6006],{"class":1129,"line":1392},[1127,6007,4798],{"class":1654},[1127,6009,6010,6012,6014,6016],{"class":1129,"line":1413},[1127,6011,4803],{"class":1654},[1127,6013,1752],{"class":1144},[1127,6015,3126],{"class":2216},[1127,6017,3882],{"class":1144},[1127,6019,6020,6022,6024,6026,6028,6030,6032,6034,6037],{"class":1129,"line":1433},[1127,6021,4814],{"class":1251},[1127,6023,1162],{"class":1158},[1127,6025,1286],{"class":1238},[1127,6027,5887],{"class":2216},[1127,6029,1752],{"class":1144},[1127,6031,3071],{"class":3070},[1127,6033,1255],{"class":1238},[1127,6035,6036],{"class":1158}," completed'",[1127,6038,1172],{"class":1144},[1127,6040,6041,6043],{"class":1129,"line":1438},[1127,6042,4824],{"class":3383},[1127,6044,4611],{"class":1144},[1127,6046,6047,6049,6052,6054,6056,6058,6060,6062],{"class":1129,"line":1452},[1127,6048,4831],{"class":1154},[1127,6050,6051],{"class":1158},"function",[1127,6053,1162],{"class":1154},[1127,6055,1165],{"class":1144},[1127,6057,5971],{"class":2216},[1127,6059,1752],{"class":1144},[1127,6061,3071],{"class":3070},[1127,6063,1172],{"class":1144},[1127,6065,6066,6068,6070,6072,6074,6076,6078,6080,6082,6084,6086,6088],{"class":1129,"line":1472},[1127,6067,4831],{"class":1154},[1127,6069,4925],{"class":1158},[1127,6071,1162],{"class":1154},[1127,6073,1165],{"class":1144},[1127,6075,4932],{"class":1251},[1127,6077,1162],{"class":1158},[1127,6079,1286],{"class":1238},[1127,6081,4925],{"class":2216},[1127,6083,4941],{"class":1251},[1127,6085,1255],{"class":1238},[1127,6087,5595],{"class":1158},[1127,6089,1172],{"class":1144},[1127,6091,6092,6094,6096,6098,6100,6102,6104],{"class":1129,"line":1493},[1127,6093,4831],{"class":1154},[1127,6095,3272],{"class":1158},[1127,6097,1162],{"class":1154},[1127,6099,1165],{"class":1144},[1127,6101,1235],{"class":1154},[1127,6103,3281],{"class":1158},[1127,6105,6106],{"class":1154},"'\n",[1127,6108,6109],{"class":1129,"line":1512},[1127,6110,4951],{"class":1144},[1127,6112,6113],{"class":1129,"line":1517},[1127,6114,4956],{"class":1144},[1127,6116,6117],{"class":1129,"line":1522},[1127,6118,4798],{"class":1654},[1127,6120,6121,6124],{"class":1129,"line":1536},[1127,6122,6123],{"class":1650},"            return",[1127,6125,6126],{"class":1654}," result\n",[1127,6128,6129,6132,6134,6136,6138],{"class":1129,"line":1549},[1127,6130,6131],{"class":1650},"        except",[1127,6133,3308],{"class":3307},[1127,6135,3311],{"class":1650},[1127,6137,3314],{"class":1654},[1127,6139,3210],{"class":1144},[1127,6141,6142,6144,6146,6148,6150,6152,6154,6156],{"class":1129,"line":1581},[1127,6143,4774],{"class":1654},[1127,6145,3057],{"class":1144},[1127,6147,4178],{"class":1654},[1127,6149,1752],{"class":1144},[1127,6151,4183],{"class":2216},[1127,6153,1896],{"class":1144},[1127,6155,4237],{"class":2262},[1127,6157,4240],{"class":1654},[1127,6159,6160],{"class":1129,"line":1602},[1127,6161,4798],{"class":1654},[1127,6163,6164,6166,6168,6170],{"class":1129,"line":1619},[1127,6165,4803],{"class":1654},[1127,6167,1752],{"class":1144},[1127,6169,3166],{"class":2216},[1127,6171,3882],{"class":1144},[1127,6173,6174,6176,6178,6180,6182,6184,6186,6188,6191],{"class":1129,"line":1624},[1127,6175,4814],{"class":1251},[1127,6177,1162],{"class":1158},[1127,6179,1286],{"class":1238},[1127,6181,5887],{"class":2216},[1127,6183,1752],{"class":1144},[1127,6185,3071],{"class":3070},[1127,6187,1255],{"class":1238},[1127,6189,6190],{"class":1158}," failed'",[1127,6192,1172],{"class":1144},[1127,6194,6195,6197],{"class":1129,"line":1629},[1127,6196,4824],{"class":3383},[1127,6198,4611],{"class":1144},[1127,6200,6201,6203,6205,6207,6209,6211,6213,6215],{"class":1129,"line":2099},[1127,6202,4831],{"class":1154},[1127,6204,6051],{"class":1158},[1127,6206,1162],{"class":1154},[1127,6208,1165],{"class":1144},[1127,6210,5971],{"class":2216},[1127,6212,1752],{"class":1144},[1127,6214,3071],{"class":3070},[1127,6216,1172],{"class":1144},[1127,6218,6219,6221,6223,6225,6227,6229,6231,6233,6235,6237,6239,6241],{"class":1129,"line":2118},[1127,6220,4831],{"class":1154},[1127,6222,4925],{"class":1158},[1127,6224,1162],{"class":1154},[1127,6226,1165],{"class":1144},[1127,6228,4932],{"class":1251},[1127,6230,1162],{"class":1158},[1127,6232,1286],{"class":1238},[1127,6234,4925],{"class":2216},[1127,6236,4941],{"class":1251},[1127,6238,1255],{"class":1238},[1127,6240,5595],{"class":1158},[1127,6242,1172],{"class":1144},[1127,6244,6245,6247,6249,6251,6253,6255,6257,6259],{"class":1129,"line":2137},[1127,6246,4831],{"class":1154},[1127,6248,3272],{"class":1158},[1127,6250,1162],{"class":1154},[1127,6252,1165],{"class":1144},[1127,6254,1235],{"class":1154},[1127,6256,3166],{"class":1158},[1127,6258,1162],{"class":1154},[1127,6260,1172],{"class":1144},[1127,6262,6263,6265,6267,6269,6271,6273,6275,6277],{"class":1129,"line":2142},[1127,6264,4831],{"class":1154},[1127,6266,3166],{"class":1158},[1127,6268,1162],{"class":1154},[1127,6270,1165],{"class":1144},[1127,6272,3372],{"class":3307},[1127,6274,2220],{"class":1144},[1127,6276,3377],{"class":2216},[1127,6278,3074],{"class":1144},[1127,6280,6281],{"class":1129,"line":2155},[1127,6282,6283],{"class":1144},"                },\n",[1127,6285,6286,6289,6291],{"class":1129,"line":2174},[1127,6287,6288],{"class":3383},"                exc_info",[1127,6290,3057],{"class":1144},[1127,6292,5121],{"class":1187},[1127,6294,6295],{"class":1129,"line":2194},[1127,6296,4956],{"class":1144},[1127,6298,6299],{"class":1129,"line":2247},[1127,6300,6301],{"class":1650},"            raise\n",[1127,6303,6304],{"class":1129,"line":2278},[1127,6305,3202],{"class":1654},[1127,6307,6308,6311],{"class":1129,"line":2295},[1127,6309,6310],{"class":1650},"    return",[1127,6312,6313],{"class":1654}," wrapper\n",[1127,6315,6316],{"class":1129,"line":2314},[1127,6317,1661],{"emptyLinePlaceholder":1660},[1127,6319,6320],{"class":1129,"line":2319},[1127,6321,4138],{"class":1133},[1127,6323,6324,6327],{"class":1129,"line":2333},[1127,6325,6326],{"class":1144},"@",[1127,6328,6329],{"class":3086},"log_performance\n",[1127,6331,6332,6334,6337],{"class":1129,"line":2353},[1127,6333,3083],{"class":1251},[1127,6335,6336],{"class":3086}," expensive_operation",[1127,6338,6339],{"class":1144},"():\n",[1127,6341,6342],{"class":1129,"line":2372},[1127,6343,6344],{"class":1133},"    # Your code here\n",[1127,6346,6347],{"class":1129,"line":2416},[1127,6348,6349],{"class":1650},"    pass\n",[1038,6351,6353],{"id":6352},"security-event-logging","Security Event Logging",[1118,6355,6357],{"className":1120,"code":6356,"language":1122,"meta":1123,"style":1123},"# security/logging.py\nimport logging\n\nsecurity_logger = logging.getLogger('security')\n\ndef log_security_event(event_type, request, **kwargs):\n    \"\"\"Log security-related events\"\"\"\n    security_logger.warning(\n        f'Security event: {event_type}',\n        extra={\n            'event_type': event_type,\n            'user': str(request.user),\n            'ip_address': get_client_ip(request),\n            'path': request.path,\n            'user_agent': request.META.get('HTTP_USER_AGENT', ''),\n            **kwargs\n        }\n    )\n\n# Usage in views\ndef login_view(request):\n    if request.method == 'POST':\n        username = request.POST.get('username')\n        password = request.POST.get('password')\n        \n        user = authenticate(request, username=username, password=password)\n        \n        if user is not None:\n            login(request, user)\n            security_logger.info(\n                'Successful login',\n                extra={'user': username, 'ip': get_client_ip(request)}\n            )\n            return redirect('dashboard')\n        else:\n            log_security_event('failed_login', request, username=username)\n            return render(request, 'login.html', {'error': 'Invalid credentials'})\n",[1075,6358,6359,6364,6370,6374,6398,6402,6425,6434,6445,6463,6470,6484,6506,6525,6543,6580,6586,6590,6595,6599,6604,6617,6640,6668,6696,6700,6734,6738,6756,6772,6783,6794,6829,6833,6851,6857,6885],{"__ignoreMap":1123},[1127,6360,6361],{"class":1129,"line":1130},[1127,6362,6363],{"class":1133},"# security/logging.py\n",[1127,6365,6366,6368],{"class":1129,"line":1137},[1127,6367,1651],{"class":1650},[1127,6369,3045],{"class":1654},[1127,6371,6372],{"class":1129,"line":1151},[1127,6373,1661],{"emptyLinePlaceholder":1660},[1127,6375,6376,6379,6381,6383,6385,6387,6389,6391,6394,6396],{"class":1129,"line":1175},[1127,6377,6378],{"class":1654},"security_logger ",[1127,6380,3057],{"class":1144},[1127,6382,3060],{"class":1654},[1127,6384,1752],{"class":1144},[1127,6386,3065],{"class":2216},[1127,6388,2220],{"class":1144},[1127,6390,1162],{"class":1154},[1127,6392,6393],{"class":1158},"security",[1127,6395,1162],{"class":1154},[1127,6397,3074],{"class":1144},[1127,6399,6400],{"class":1129,"line":1193},[1127,6401,1661],{"emptyLinePlaceholder":1660},[1127,6403,6404,6406,6409,6411,6413,6415,6417,6419,6421,6423],{"class":1129,"line":1207},[1127,6405,3083],{"class":1251},[1127,6407,6408],{"class":3086}," log_security_event",[1127,6410,2220],{"class":1144},[1127,6412,3592],{"class":3092},[1127,6414,1569],{"class":1144},[1127,6416,3840],{"class":3092},[1127,6418,1569],{"class":1144},[1127,6420,3530],{"class":2262},[1127,6422,3533],{"class":3092},[1127,6424,3096],{"class":1144},[1127,6426,6427,6429,6432],{"class":1129,"line":1222},[1127,6428,5894],{"class":3540},[1127,6430,6431],{"class":3544},"Log security-related events",[1127,6433,3548],{"class":3540},[1127,6435,6436,6439,6441,6443],{"class":1129,"line":1272},[1127,6437,6438],{"class":1654},"    security_logger",[1127,6440,1752],{"class":1144},[1127,6442,3146],{"class":2216},[1127,6444,3882],{"class":1144},[1127,6446,6447,6450,6453,6455,6457,6459,6461],{"class":1129,"line":1293},[1127,6448,6449],{"class":1251},"        f",[1127,6451,6452],{"class":1158},"'Security event: ",[1127,6454,1286],{"class":1238},[1127,6456,3592],{"class":2216},[1127,6458,1255],{"class":1238},[1127,6460,1162],{"class":1158},[1127,6462,1172],{"class":1144},[1127,6464,6465,6468],{"class":1129,"line":1299},[1127,6466,6467],{"class":3383},"        extra",[1127,6469,4611],{"class":1144},[1127,6471,6472,6474,6476,6478,6480,6482],{"class":1129,"line":1313},[1127,6473,1225],{"class":1154},[1127,6475,3592],{"class":1158},[1127,6477,1162],{"class":1154},[1127,6479,1165],{"class":1144},[1127,6481,3512],{"class":2216},[1127,6483,1172],{"class":1144},[1127,6485,6486,6488,6490,6492,6494,6496,6498,6500,6502,6504],{"class":1129,"line":1334},[1127,6487,1225],{"class":1154},[1127,6489,3943],{"class":1158},[1127,6491,1162],{"class":1154},[1127,6493,1165],{"class":1144},[1127,6495,3372],{"class":3307},[1127,6497,2220],{"class":1144},[1127,6499,3093],{"class":2216},[1127,6501,1752],{"class":1144},[1127,6503,3943],{"class":2210},[1127,6505,2244],{"class":1144},[1127,6507,6508,6510,6513,6515,6517,6519,6521,6523],{"class":1129,"line":1353},[1127,6509,1225],{"class":1154},[1127,6511,6512],{"class":1158},"ip_address",[1127,6514,1162],{"class":1154},[1127,6516,1165],{"class":1144},[1127,6518,4011],{"class":2216},[1127,6520,2220],{"class":1144},[1127,6522,3093],{"class":2216},[1127,6524,2244],{"class":1144},[1127,6526,6527,6529,6531,6533,6535,6537,6539,6541],{"class":1129,"line":1358},[1127,6528,1225],{"class":1154},[1127,6530,2211],{"class":1158},[1127,6532,1162],{"class":1154},[1127,6534,1165],{"class":1144},[1127,6536,3840],{"class":2216},[1127,6538,1752],{"class":1144},[1127,6540,2211],{"class":2210},[1127,6542,1172],{"class":1144},[1127,6544,6545,6547,6550,6552,6554,6556,6558,6560,6562,6564,6566,6568,6571,6573,6575,6578],{"class":1129,"line":1364},[1127,6546,1225],{"class":1154},[1127,6548,6549],{"class":1158},"user_agent",[1127,6551,1162],{"class":1154},[1127,6553,1165],{"class":1144},[1127,6555,3840],{"class":2216},[1127,6557,1752],{"class":1144},[1127,6559,4032],{"class":4031},[1127,6561,1752],{"class":1144},[1127,6563,4037],{"class":2216},[1127,6565,2220],{"class":1144},[1127,6567,1162],{"class":1154},[1127,6569,6570],{"class":1158},"HTTP_USER_AGENT",[1127,6572,1162],{"class":1154},[1127,6574,1569],{"class":1144},[1127,6576,6577],{"class":1154}," ''",[1127,6579,2244],{"class":1144},[1127,6581,6582,6584],{"class":1129,"line":1378},[1127,6583,3605],{"class":2262},[1127,6585,3608],{"class":2216},[1127,6587,6588],{"class":1129,"line":1392},[1127,6589,3613],{"class":1144},[1127,6591,6592],{"class":1129,"line":1413},[1127,6593,6594],{"class":1144},"    )\n",[1127,6596,6597],{"class":1129,"line":1433},[1127,6598,1661],{"emptyLinePlaceholder":1660},[1127,6600,6601],{"class":1129,"line":1438},[1127,6602,6603],{"class":1133},"# Usage in views\n",[1127,6605,6606,6608,6611,6613,6615],{"class":1129,"line":1452},[1127,6607,3083],{"class":1251},[1127,6609,6610],{"class":3086}," login_view",[1127,6612,2220],{"class":1144},[1127,6614,3093],{"class":3092},[1127,6616,3096],{"class":1144},[1127,6618,6619,6622,6624,6626,6628,6631,6633,6636,6638],{"class":1129,"line":1472},[1127,6620,6621],{"class":1650},"    if",[1127,6623,3840],{"class":1654},[1127,6625,1752],{"class":1144},[1127,6627,3907],{"class":2210},[1127,6629,6630],{"class":2262}," ==",[1127,6632,1235],{"class":1154},[1127,6634,6635],{"class":1158},"POST",[1127,6637,1162],{"class":1154},[1127,6639,3210],{"class":1144},[1127,6641,6642,6645,6647,6649,6651,6653,6655,6657,6659,6661,6664,6666],{"class":1129,"line":1493},[1127,6643,6644],{"class":1654},"        username ",[1127,6646,3057],{"class":1144},[1127,6648,3840],{"class":1654},[1127,6650,1752],{"class":1144},[1127,6652,6635],{"class":4031},[1127,6654,1752],{"class":1144},[1127,6656,4037],{"class":2216},[1127,6658,2220],{"class":1144},[1127,6660,1162],{"class":1154},[1127,6662,6663],{"class":1158},"username",[1127,6665,1162],{"class":1154},[1127,6667,3074],{"class":1144},[1127,6669,6670,6673,6675,6677,6679,6681,6683,6685,6687,6689,6692,6694],{"class":1129,"line":1512},[1127,6671,6672],{"class":1654},"        password ",[1127,6674,3057],{"class":1144},[1127,6676,3840],{"class":1654},[1127,6678,1752],{"class":1144},[1127,6680,6635],{"class":4031},[1127,6682,1752],{"class":1144},[1127,6684,4037],{"class":2216},[1127,6686,2220],{"class":1144},[1127,6688,1162],{"class":1154},[1127,6690,6691],{"class":1158},"password",[1127,6693,1162],{"class":1154},[1127,6695,3074],{"class":1144},[1127,6697,6698],{"class":1129,"line":1517},[1127,6699,3618],{"class":1654},[1127,6701,6702,6705,6707,6710,6712,6714,6716,6719,6721,6723,6725,6728,6730,6732],{"class":1129,"line":1522},[1127,6703,6704],{"class":1654},"        user ",[1127,6706,3057],{"class":1144},[1127,6708,6709],{"class":2216}," authenticate",[1127,6711,2220],{"class":1144},[1127,6713,3093],{"class":2216},[1127,6715,1569],{"class":1144},[1127,6717,6718],{"class":3383}," username",[1127,6720,3057],{"class":1144},[1127,6722,6663],{"class":2216},[1127,6724,1569],{"class":1144},[1127,6726,6727],{"class":3383}," password",[1127,6729,3057],{"class":1144},[1127,6731,6691],{"class":2216},[1127,6733,3074],{"class":1144},[1127,6735,6736],{"class":1129,"line":1536},[1127,6737,3618],{"class":1654},[1127,6739,6740,6742,6745,6748,6751,6754],{"class":1129,"line":1549},[1127,6741,3649],{"class":1650},[1127,6743,6744],{"class":1654}," user ",[1127,6746,6747],{"class":2262},"is",[1127,6749,6750],{"class":2262}," not",[1127,6752,6753],{"class":1187}," None",[1127,6755,3210],{"class":1144},[1127,6757,6758,6761,6763,6765,6767,6770],{"class":1129,"line":1581},[1127,6759,6760],{"class":2216},"            login",[1127,6762,2220],{"class":1144},[1127,6764,3093],{"class":2216},[1127,6766,1569],{"class":1144},[1127,6768,6769],{"class":2216}," user",[1127,6771,3074],{"class":1144},[1127,6773,6774,6777,6779,6781],{"class":1129,"line":1602},[1127,6775,6776],{"class":1654},"            security_logger",[1127,6778,1752],{"class":1144},[1127,6780,3126],{"class":2216},[1127,6782,3882],{"class":1144},[1127,6784,6785,6787,6790,6792],{"class":1129,"line":1619},[1127,6786,4616],{"class":1154},[1127,6788,6789],{"class":1158},"Successful login",[1127,6791,1162],{"class":1154},[1127,6793,1172],{"class":1144},[1127,6795,6796,6798,6800,6802,6804,6806,6808,6810,6812,6814,6816,6818,6820,6822,6824,6826],{"class":1129,"line":1624},[1127,6797,4824],{"class":3383},[1127,6799,5767],{"class":1144},[1127,6801,1162],{"class":1154},[1127,6803,3943],{"class":1158},[1127,6805,1162],{"class":1154},[1127,6807,1165],{"class":1144},[1127,6809,6718],{"class":2216},[1127,6811,1569],{"class":1144},[1127,6813,1235],{"class":1154},[1127,6815,4696],{"class":1158},[1127,6817,1162],{"class":1154},[1127,6819,1165],{"class":1144},[1127,6821,4011],{"class":2216},[1127,6823,2220],{"class":1144},[1127,6825,3093],{"class":2216},[1127,6827,6828],{"class":1144},")}\n",[1127,6830,6831],{"class":1129,"line":1629},[1127,6832,4956],{"class":1144},[1127,6834,6835,6837,6840,6842,6844,6847,6849],{"class":1129,"line":2099},[1127,6836,6123],{"class":1650},[1127,6838,6839],{"class":2216}," redirect",[1127,6841,2220],{"class":1144},[1127,6843,1162],{"class":1154},[1127,6845,6846],{"class":1158},"dashboard",[1127,6848,1162],{"class":1154},[1127,6850,3074],{"class":1144},[1127,6852,6853,6855],{"class":1129,"line":2118},[1127,6854,4093],{"class":1650},[1127,6856,3210],{"class":1144},[1127,6858,6859,6862,6864,6866,6869,6871,6873,6875,6877,6879,6881,6883],{"class":1129,"line":2137},[1127,6860,6861],{"class":2216},"            log_security_event",[1127,6863,2220],{"class":1144},[1127,6865,1162],{"class":1154},[1127,6867,6868],{"class":1158},"failed_login",[1127,6870,1162],{"class":1154},[1127,6872,1569],{"class":1144},[1127,6874,3840],{"class":2216},[1127,6876,1569],{"class":1144},[1127,6878,6718],{"class":3383},[1127,6880,3057],{"class":1144},[1127,6882,6663],{"class":2216},[1127,6884,3074],{"class":1144},[1127,6886,6887,6889,6892,6894,6896,6898,6900,6903,6905,6907,6910,6912,6914,6916,6918,6920,6923,6925],{"class":1129,"line":2142},[1127,6888,6123],{"class":1650},[1127,6890,6891],{"class":2216}," render",[1127,6893,2220],{"class":1144},[1127,6895,3093],{"class":2216},[1127,6897,1569],{"class":1144},[1127,6899,1235],{"class":1154},[1127,6901,6902],{"class":1158},"login.html",[1127,6904,1162],{"class":1154},[1127,6906,1569],{"class":1144},[1127,6908,6909],{"class":1144}," {",[1127,6911,1162],{"class":1154},[1127,6913,3166],{"class":1158},[1127,6915,1162],{"class":1154},[1127,6917,1165],{"class":1144},[1127,6919,1235],{"class":1154},[1127,6921,6922],{"class":1158},"Invalid credentials",[1127,6924,1162],{"class":1154},[1127,6926,3299],{"class":1144},[1030,6928,6930],{"id":6929},"external-logging-services","External Logging Services",[1038,6932,6934],{"id":6933},"sentry-integration","Sentry Integration",[1118,6936,6938],{"className":1120,"code":6937,"language":1122,"meta":1123,"style":1123},"# settings.py\nimport sentry_sdk\nfrom sentry_sdk.integrations.django import DjangoIntegration\nfrom sentry_sdk.integrations.logging import LoggingIntegration\n\nsentry_logging = LoggingIntegration(\n    level=logging.INFO,\n    event_level=logging.ERROR\n)\n\nsentry_sdk.init(\n    dsn=\"your-sentry-dsn\",\n    integrations=[\n        DjangoIntegration(),\n        sentry_logging,\n    ],\n    traces_sample_rate=0.1,\n    send_default_pii=True,\n    environment=os.environ.get('ENVIRONMENT', 'development'),\n)\n\n# Custom Sentry logging\nimport sentry_sdk\n\ndef my_view(request):\n    try:\n        # Your code\n        pass\n    except Exception as e:\n        sentry_sdk.capture_exception(e)\n        sentry_sdk.capture_message('Custom error message', level='error')\n        \n        # Add context\n        with sentry_sdk.configure_scope() as scope:\n            scope.set_tag('custom_tag', 'value')\n            scope.set_context('custom_context', {\n                'key': 'value'\n            })\n",[1075,6939,6940,6944,6951,6973,6993,6997,7009,7025,7039,7043,7047,7059,7075,7083,7090,7097,7102,7114,7126,7165,7169,7173,7178,7184,7188,7200,7206,7211,7216,7228,7244,7276,7280,7285,7306,7336,7358,7375],{"__ignoreMap":1123},[1127,6941,6942],{"class":1129,"line":1130},[1127,6943,1134],{"class":1133},[1127,6945,6946,6948],{"class":1129,"line":1137},[1127,6947,1651],{"class":1650},[1127,6949,6950],{"class":1654}," sentry_sdk\n",[1127,6952,6953,6955,6958,6960,6963,6965,6968,6970],{"class":1129,"line":1151},[1127,6954,3423],{"class":1650},[1127,6956,6957],{"class":1654}," sentry_sdk",[1127,6959,1752],{"class":1144},[1127,6961,6962],{"class":1654},"integrations",[1127,6964,1752],{"class":1144},[1127,6966,6967],{"class":1654},"django ",[1127,6969,1651],{"class":1650},[1127,6971,6972],{"class":1654}," DjangoIntegration\n",[1127,6974,6975,6977,6979,6981,6983,6985,6988,6990],{"class":1129,"line":1175},[1127,6976,3423],{"class":1650},[1127,6978,6957],{"class":1654},[1127,6980,1752],{"class":1144},[1127,6982,6962],{"class":1654},[1127,6984,1752],{"class":1144},[1127,6986,6987],{"class":1654},"logging ",[1127,6989,1651],{"class":1650},[1127,6991,6992],{"class":1654}," LoggingIntegration\n",[1127,6994,6995],{"class":1129,"line":1193},[1127,6996,1661],{"emptyLinePlaceholder":1660},[1127,6998,6999,7002,7004,7007],{"class":1129,"line":1207},[1127,7000,7001],{"class":1654},"sentry_logging ",[1127,7003,3057],{"class":1144},[1127,7005,7006],{"class":2216}," LoggingIntegration",[1127,7008,3882],{"class":1144},[1127,7010,7011,7014,7016,7019,7021,7023],{"class":1129,"line":1222},[1127,7012,7013],{"class":3383},"    level",[1127,7015,3057],{"class":1144},[1127,7017,7018],{"class":2216},"logging",[1127,7020,1752],{"class":1144},[1127,7022,1595],{"class":4031},[1127,7024,1172],{"class":1144},[1127,7026,7027,7030,7032,7034,7036],{"class":1129,"line":1272},[1127,7028,7029],{"class":3383},"    event_level",[1127,7031,3057],{"class":1144},[1127,7033,7018],{"class":2216},[1127,7035,1752],{"class":1144},[1127,7037,7038],{"class":4031},"ERROR\n",[1127,7040,7041],{"class":1129,"line":1293},[1127,7042,3074],{"class":1144},[1127,7044,7045],{"class":1129,"line":1299},[1127,7046,1661],{"emptyLinePlaceholder":1660},[1127,7048,7049,7052,7054,7057],{"class":1129,"line":1313},[1127,7050,7051],{"class":1654},"sentry_sdk",[1127,7053,1752],{"class":1144},[1127,7055,7056],{"class":2216},"init",[1127,7058,3882],{"class":1144},[1127,7060,7061,7064,7066,7068,7071,7073],{"class":1129,"line":1334},[1127,7062,7063],{"class":3383},"    dsn",[1127,7065,3057],{"class":1144},[1127,7067,5747],{"class":1154},[1127,7069,7070],{"class":1158},"your-sentry-dsn",[1127,7072,5747],{"class":1154},[1127,7074,1172],{"class":1144},[1127,7076,7077,7080],{"class":1129,"line":1353},[1127,7078,7079],{"class":3383},"    integrations",[1127,7081,7082],{"class":1144},"=[\n",[1127,7084,7085,7088],{"class":1129,"line":1358},[1127,7086,7087],{"class":2216},"        DjangoIntegration",[1127,7089,3585],{"class":1144},[1127,7091,7092,7095],{"class":1129,"line":1364},[1127,7093,7094],{"class":2216},"        sentry_logging",[1127,7096,1172],{"class":1144},[1127,7098,7099],{"class":1129,"line":1378},[1127,7100,7101],{"class":1144},"    ],\n",[1127,7103,7104,7107,7109,7112],{"class":1129,"line":1392},[1127,7105,7106],{"class":3383},"    traces_sample_rate",[1127,7108,3057],{"class":1144},[1127,7110,7111],{"class":1168},"0.1",[1127,7113,1172],{"class":1144},[1127,7115,7116,7119,7121,7124],{"class":1129,"line":1413},[1127,7117,7118],{"class":3383},"    send_default_pii",[1127,7120,3057],{"class":1144},[1127,7122,7123],{"class":1187},"True",[1127,7125,1172],{"class":1144},[1127,7127,7128,7131,7133,7136,7138,7141,7143,7145,7147,7149,7152,7154,7156,7158,7161,7163],{"class":1129,"line":1433},[1127,7129,7130],{"class":3383},"    environment",[1127,7132,3057],{"class":1144},[1127,7134,7135],{"class":2216},"os",[1127,7137,1752],{"class":1144},[1127,7139,7140],{"class":2210},"environ",[1127,7142,1752],{"class":1144},[1127,7144,4037],{"class":2216},[1127,7146,2220],{"class":1144},[1127,7148,1162],{"class":1154},[1127,7150,7151],{"class":1158},"ENVIRONMENT",[1127,7153,1162],{"class":1154},[1127,7155,1569],{"class":1144},[1127,7157,1235],{"class":1154},[1127,7159,7160],{"class":1158},"development",[1127,7162,1162],{"class":1154},[1127,7164,2244],{"class":1144},[1127,7166,7167],{"class":1129,"line":1438},[1127,7168,3074],{"class":1144},[1127,7170,7171],{"class":1129,"line":1452},[1127,7172,1661],{"emptyLinePlaceholder":1660},[1127,7174,7175],{"class":1129,"line":1472},[1127,7176,7177],{"class":1133},"# Custom Sentry logging\n",[1127,7179,7180,7182],{"class":1129,"line":1493},[1127,7181,1651],{"class":1650},[1127,7183,6950],{"class":1654},[1127,7185,7186],{"class":1129,"line":1512},[1127,7187,1661],{"emptyLinePlaceholder":1660},[1127,7189,7190,7192,7194,7196,7198],{"class":1129,"line":1517},[1127,7191,3083],{"class":1251},[1127,7193,3087],{"class":3086},[1127,7195,2220],{"class":1144},[1127,7197,3093],{"class":3092},[1127,7199,3096],{"class":1144},[1127,7201,7202,7204],{"class":1129,"line":1522},[1127,7203,3207],{"class":1650},[1127,7205,3210],{"class":1144},[1127,7207,7208],{"class":1129,"line":1536},[1127,7209,7210],{"class":1133},"        # Your code\n",[1127,7212,7213],{"class":1129,"line":1549},[1127,7214,7215],{"class":1650},"        pass\n",[1127,7217,7218,7220,7222,7224,7226],{"class":1129,"line":1581},[1127,7219,3304],{"class":1650},[1127,7221,3308],{"class":3307},[1127,7223,3311],{"class":1650},[1127,7225,3314],{"class":1654},[1127,7227,3210],{"class":1144},[1127,7229,7230,7233,7235,7238,7240,7242],{"class":1129,"line":1602},[1127,7231,7232],{"class":1654},"        sentry_sdk",[1127,7234,1752],{"class":1144},[1127,7236,7237],{"class":2216},"capture_exception",[1127,7239,2220],{"class":1144},[1127,7241,3377],{"class":2216},[1127,7243,3074],{"class":1144},[1127,7245,7246,7248,7250,7253,7255,7257,7260,7262,7264,7266,7268,7270,7272,7274],{"class":1129,"line":1619},[1127,7247,7232],{"class":1654},[1127,7249,1752],{"class":1144},[1127,7251,7252],{"class":2216},"capture_message",[1127,7254,2220],{"class":1144},[1127,7256,1162],{"class":1154},[1127,7258,7259],{"class":1158},"Custom error message",[1127,7261,1162],{"class":1154},[1127,7263,1569],{"class":1144},[1127,7265,3517],{"class":3383},[1127,7267,3057],{"class":1144},[1127,7269,1162],{"class":1154},[1127,7271,3166],{"class":1158},[1127,7273,1162],{"class":1154},[1127,7275,3074],{"class":1144},[1127,7277,7278],{"class":1129,"line":1624},[1127,7279,3618],{"class":1654},[1127,7281,7282],{"class":1129,"line":1629},[1127,7283,7284],{"class":1133},"        # Add context\n",[1127,7286,7287,7290,7292,7294,7297,7299,7301,7304],{"class":1129,"line":2099},[1127,7288,7289],{"class":1650},"        with",[1127,7291,6957],{"class":1654},[1127,7293,1752],{"class":1144},[1127,7295,7296],{"class":2216},"configure_scope",[1127,7298,1896],{"class":1144},[1127,7300,3311],{"class":1650},[1127,7302,7303],{"class":1654}," scope",[1127,7305,3210],{"class":1144},[1127,7307,7308,7311,7313,7316,7318,7320,7323,7325,7327,7329,7332,7334],{"class":1129,"line":2118},[1127,7309,7310],{"class":1654},"            scope",[1127,7312,1752],{"class":1144},[1127,7314,7315],{"class":2216},"set_tag",[1127,7317,2220],{"class":1144},[1127,7319,1162],{"class":1154},[1127,7321,7322],{"class":1158},"custom_tag",[1127,7324,1162],{"class":1154},[1127,7326,1569],{"class":1144},[1127,7328,1235],{"class":1154},[1127,7330,7331],{"class":1158},"value",[1127,7333,1162],{"class":1154},[1127,7335,3074],{"class":1144},[1127,7337,7338,7340,7342,7345,7347,7349,7352,7354,7356],{"class":1129,"line":2137},[1127,7339,7310],{"class":1654},[1127,7341,1752],{"class":1144},[1127,7343,7344],{"class":2216},"set_context",[1127,7346,2220],{"class":1144},[1127,7348,1162],{"class":1154},[1127,7350,7351],{"class":1158},"custom_context",[1127,7353,1162],{"class":1154},[1127,7355,1569],{"class":1144},[1127,7357,1148],{"class":1144},[1127,7359,7360,7362,7365,7367,7369,7371,7373],{"class":1129,"line":2142},[1127,7361,4616],{"class":1154},[1127,7363,7364],{"class":1158},"key",[1127,7366,1162],{"class":1154},[1127,7368,1165],{"class":1144},[1127,7370,1235],{"class":1154},[1127,7372,7331],{"class":1158},[1127,7374,6106],{"class":1154},[1127,7376,7377],{"class":1129,"line":2155},[1127,7378,7379],{"class":1144},"            })\n",[1038,7381,7383],{"id":7382},"cloudwatch-logs-integration","CloudWatch Logs Integration",[1118,7385,7387],{"className":1120,"code":7386,"language":1122,"meta":1123,"style":1123},"# settings.py\nimport boto3\nfrom watchtower import CloudWatchLogHandler\n\ncloudwatch_handler = CloudWatchLogHandler(\n    log_group='django-app',\n    stream_name='production',\n    boto3_client=boto3.client('logs', region_name='us-east-1')\n)\n\nLOGGING['handlers']['cloudwatch'] = {\n    'class': 'watchtower.CloudWatchLogHandler',\n    'log_group': 'django-app',\n    'stream_name': 'production',\n    'level': 'INFO',\n    'formatter': 'json',\n}\n\nLOGGING['loggers']['django']['handlers'].append('cloudwatch')\n",[1075,7388,7389,7393,7400,7412,7416,7428,7444,7460,7499,7503,7507,7534,7553,7572,7591,7609,7627,7631,7635],{"__ignoreMap":1123},[1127,7390,7391],{"class":1129,"line":1130},[1127,7392,1134],{"class":1133},[1127,7394,7395,7397],{"class":1129,"line":1137},[1127,7396,1651],{"class":1650},[1127,7398,7399],{"class":1654}," boto3\n",[1127,7401,7402,7404,7407,7409],{"class":1129,"line":1151},[1127,7403,3423],{"class":1650},[1127,7405,7406],{"class":1654}," watchtower ",[1127,7408,1651],{"class":1650},[1127,7410,7411],{"class":1654}," CloudWatchLogHandler\n",[1127,7413,7414],{"class":1129,"line":1175},[1127,7415,1661],{"emptyLinePlaceholder":1660},[1127,7417,7418,7421,7423,7426],{"class":1129,"line":1193},[1127,7419,7420],{"class":1654},"cloudwatch_handler ",[1127,7422,3057],{"class":1144},[1127,7424,7425],{"class":2216}," CloudWatchLogHandler",[1127,7427,3882],{"class":1144},[1127,7429,7430,7433,7435,7437,7440,7442],{"class":1129,"line":1207},[1127,7431,7432],{"class":3383},"    log_group",[1127,7434,3057],{"class":1144},[1127,7436,1162],{"class":1154},[1127,7438,7439],{"class":1158},"django-app",[1127,7441,1162],{"class":1154},[1127,7443,1172],{"class":1144},[1127,7445,7446,7449,7451,7453,7456,7458],{"class":1129,"line":1222},[1127,7447,7448],{"class":3383},"    stream_name",[1127,7450,3057],{"class":1144},[1127,7452,1162],{"class":1154},[1127,7454,7455],{"class":1158},"production",[1127,7457,1162],{"class":1154},[1127,7459,1172],{"class":1144},[1127,7461,7462,7465,7467,7470,7472,7475,7477,7479,7481,7483,7485,7488,7490,7492,7495,7497],{"class":1129,"line":1272},[1127,7463,7464],{"class":3383},"    boto3_client",[1127,7466,3057],{"class":1144},[1127,7468,7469],{"class":2216},"boto3",[1127,7471,1752],{"class":1144},[1127,7473,7474],{"class":2216},"client",[1127,7476,2220],{"class":1144},[1127,7478,1162],{"class":1154},[1127,7480,2231],{"class":1158},[1127,7482,1162],{"class":1154},[1127,7484,1569],{"class":1144},[1127,7486,7487],{"class":3383}," region_name",[1127,7489,3057],{"class":1144},[1127,7491,1162],{"class":1154},[1127,7493,7494],{"class":1158},"us-east-1",[1127,7496,1162],{"class":1154},[1127,7498,3074],{"class":1144},[1127,7500,7501],{"class":1129,"line":1293},[1127,7502,3074],{"class":1144},[1127,7504,7505],{"class":1129,"line":1299},[1127,7506,1661],{"emptyLinePlaceholder":1660},[1127,7508,7509,7511,7513,7515,7517,7519,7521,7523,7526,7528,7530,7532],{"class":1129,"line":1313},[1127,7510,1141],{"class":1140},[1127,7512,1736],{"class":1144},[1127,7514,1162],{"class":1154},[1127,7516,1369],{"class":1158},[1127,7518,1162],{"class":1154},[1127,7520,5288],{"class":1144},[1127,7522,1162],{"class":1154},[1127,7524,7525],{"class":1158},"cloudwatch",[1127,7527,1162],{"class":1154},[1127,7529,5297],{"class":1144},[1127,7531,1145],{"class":1144},[1127,7533,1148],{"class":1144},[1127,7535,7536,7538,7540,7542,7544,7546,7549,7551],{"class":1129,"line":1334},[1127,7537,1155],{"class":1154},[1127,7539,1397],{"class":1158},[1127,7541,1162],{"class":1154},[1127,7543,1165],{"class":1144},[1127,7545,1235],{"class":1154},[1127,7547,7548],{"class":1158},"watchtower.CloudWatchLogHandler",[1127,7550,1162],{"class":1154},[1127,7552,1172],{"class":1144},[1127,7554,7555,7557,7560,7562,7564,7566,7568,7570],{"class":1129,"line":1353},[1127,7556,1155],{"class":1154},[1127,7558,7559],{"class":1158},"log_group",[1127,7561,1162],{"class":1154},[1127,7563,1165],{"class":1144},[1127,7565,1235],{"class":1154},[1127,7567,7439],{"class":1158},[1127,7569,1162],{"class":1154},[1127,7571,1172],{"class":1144},[1127,7573,7574,7576,7579,7581,7583,7585,7587,7589],{"class":1129,"line":1358},[1127,7575,1155],{"class":1154},[1127,7577,7578],{"class":1158},"stream_name",[1127,7580,1162],{"class":1154},[1127,7582,1165],{"class":1144},[1127,7584,1235],{"class":1154},[1127,7586,7455],{"class":1158},[1127,7588,1162],{"class":1154},[1127,7590,1172],{"class":1144},[1127,7592,7593,7595,7597,7599,7601,7603,7605,7607],{"class":1129,"line":1364},[1127,7594,1155],{"class":1154},[1127,7596,1586],{"class":1158},[1127,7598,1162],{"class":1154},[1127,7600,1165],{"class":1144},[1127,7602,1235],{"class":1154},[1127,7604,1595],{"class":1158},[1127,7606,1162],{"class":1154},[1127,7608,1172],{"class":1144},[1127,7610,7611,7613,7615,7617,7619,7621,7623,7625],{"class":1129,"line":1378},[1127,7612,1155],{"class":1154},[1127,7614,1418],{"class":1158},[1127,7616,1162],{"class":1154},[1127,7618,1165],{"class":1144},[1127,7620,1235],{"class":1154},[1127,7622,1883],{"class":1158},[1127,7624,1162],{"class":1154},[1127,7626,1172],{"class":1144},[1127,7628,7629],{"class":1129,"line":1392},[1127,7630,1632],{"class":1144},[1127,7632,7633],{"class":1129,"line":1413},[1127,7634,1661],{"emptyLinePlaceholder":1660},[1127,7636,7637,7639,7641,7643,7645,7647,7649,7651,7653,7655,7657,7659,7661,7663,7666,7669,7671,7673,7675,7677],{"class":1129,"line":1433},[1127,7638,1141],{"class":1140},[1127,7640,1736],{"class":1144},[1127,7642,1162],{"class":1154},[1127,7644,1527],{"class":1158},[1127,7646,1162],{"class":1154},[1127,7648,5288],{"class":1144},[1127,7650,1162],{"class":1154},[1127,7652,1077],{"class":1158},[1127,7654,1162],{"class":1154},[1127,7656,5288],{"class":1144},[1127,7658,1162],{"class":1154},[1127,7660,1369],{"class":1158},[1127,7662,1162],{"class":1154},[1127,7664,7665],{"class":1144},"].",[1127,7667,7668],{"class":2216},"append",[1127,7670,2220],{"class":1144},[1127,7672,1162],{"class":1154},[1127,7674,7525],{"class":1158},[1127,7676,1162],{"class":1154},[1127,7678,3074],{"class":1144},[1030,7680,7682],{"id":7681},"testing-logging","Testing Logging",[1118,7684,7686],{"className":1120,"code":7685,"language":1122,"meta":1123,"style":1123},"# tests.py\nfrom django.test import TestCase\nimport logging\n\nclass LoggingTests(TestCase):\n    def test_logging_output(self):\n        \"\"\"Test that logging works correctly\"\"\"\n        with self.assertLogs('myapp', level='INFO') as cm:\n            logger = logging.getLogger('myapp')\n            logger.info('Test message')\n            \n            self.assertEqual(len(cm.output), 1)\n            self.assertIn('Test message', cm.output[0])\n    \n    def test_error_logging(self):\n        \"\"\"Test error logging\"\"\"\n        with self.assertLogs('myapp', level='ERROR') as cm:\n            logger = logging.getLogger('myapp')\n            \n            try:\n                raise ValueError('Test error')\n            except ValueError:\n                logger.exception('An error occurred')\n            \n            self.assertEqual(len(cm.output), 1)\n            self.assertIn('An error occurred', cm.output[0])\n",[1075,7687,7688,7693,7709,7715,7719,7733,7746,7755,7795,7818,7837,7841,7871,7903,7907,7920,7929,7967,7989,7993,8000,8019,8028,8048,8052,8078],{"__ignoreMap":1123},[1127,7689,7690],{"class":1129,"line":1130},[1127,7691,7692],{"class":1133},"# tests.py\n",[1127,7694,7695,7697,7699,7701,7704,7706],{"class":1129,"line":1137},[1127,7696,3423],{"class":1650},[1127,7698,4456],{"class":1654},[1127,7700,1752],{"class":1144},[1127,7702,7703],{"class":1654},"test ",[1127,7705,1651],{"class":1650},[1127,7707,7708],{"class":1654}," TestCase\n",[1127,7710,7711,7713],{"class":1129,"line":1151},[1127,7712,1651],{"class":1650},[1127,7714,3045],{"class":1654},[1127,7716,7717],{"class":1129,"line":1175},[1127,7718,1661],{"emptyLinePlaceholder":1660},[1127,7720,7721,7723,7726,7728,7731],{"class":1129,"line":1193},[1127,7722,1397],{"class":1251},[1127,7724,7725],{"class":3442}," LoggingTests",[1127,7727,2220],{"class":1144},[1127,7729,7730],{"class":4509},"TestCase",[1127,7732,3096],{"class":1144},[1127,7734,7735,7737,7740,7742,7744],{"class":1129,"line":1207},[1127,7736,3450],{"class":1251},[1127,7738,7739],{"class":3086}," test_logging_output",[1127,7741,2220],{"class":1144},[1127,7743,3460],{"class":3459},[1127,7745,3096],{"class":1144},[1127,7747,7748,7750,7753],{"class":1129,"line":1222},[1127,7749,3541],{"class":3540},[1127,7751,7752],{"class":3544},"Test that logging works correctly",[1127,7754,3548],{"class":3540},[1127,7756,7757,7759,7761,7763,7766,7768,7770,7772,7774,7776,7778,7780,7782,7784,7786,7788,7790,7793],{"class":1129,"line":1272},[1127,7758,7289],{"class":1650},[1127,7760,4703],{"class":1140},[1127,7762,1752],{"class":1144},[1127,7764,7765],{"class":2216},"assertLogs",[1127,7767,2220],{"class":1144},[1127,7769,1162],{"class":1154},[1127,7771,2849],{"class":1158},[1127,7773,1162],{"class":1154},[1127,7775,1569],{"class":1144},[1127,7777,3517],{"class":3383},[1127,7779,3057],{"class":1144},[1127,7781,1162],{"class":1154},[1127,7783,1595],{"class":1158},[1127,7785,1162],{"class":1154},[1127,7787,5578],{"class":1144},[1127,7789,3311],{"class":1650},[1127,7791,7792],{"class":1654}," cm",[1127,7794,3210],{"class":1144},[1127,7796,7797,7800,7802,7804,7806,7808,7810,7812,7814,7816],{"class":1129,"line":1293},[1127,7798,7799],{"class":1654},"            logger ",[1127,7801,3057],{"class":1144},[1127,7803,3060],{"class":1654},[1127,7805,1752],{"class":1144},[1127,7807,3065],{"class":2216},[1127,7809,2220],{"class":1144},[1127,7811,1162],{"class":1154},[1127,7813,2849],{"class":1158},[1127,7815,1162],{"class":1154},[1127,7817,3074],{"class":1144},[1127,7819,7820,7822,7824,7826,7828,7830,7833,7835],{"class":1129,"line":1299},[1127,7821,4803],{"class":1654},[1127,7823,1752],{"class":1144},[1127,7825,3126],{"class":2216},[1127,7827,2220],{"class":1144},[1127,7829,1162],{"class":1154},[1127,7831,7832],{"class":1158},"Test message",[1127,7834,1162],{"class":1154},[1127,7836,3074],{"class":1144},[1127,7838,7839],{"class":1129,"line":1313},[1127,7840,4798],{"class":1654},[1127,7842,7843,7845,7847,7850,7852,7854,7856,7859,7861,7864,7867,7869],{"class":1129,"line":1334},[1127,7844,3668],{"class":1140},[1127,7846,1752],{"class":1144},[1127,7848,7849],{"class":2216},"assertEqual",[1127,7851,2220],{"class":1144},[1127,7853,5570],{"class":3453},[1127,7855,2220],{"class":1144},[1127,7857,7858],{"class":2216},"cm",[1127,7860,1752],{"class":1144},[1127,7862,7863],{"class":2210},"output",[1127,7865,7866],{"class":1144},"),",[1127,7868,1169],{"class":1168},[1127,7870,3074],{"class":1144},[1127,7872,7873,7875,7877,7880,7882,7884,7886,7888,7890,7892,7894,7896,7898,7900],{"class":1129,"line":1353},[1127,7874,3668],{"class":1140},[1127,7876,1752],{"class":1144},[1127,7878,7879],{"class":2216},"assertIn",[1127,7881,2220],{"class":1144},[1127,7883,1162],{"class":1154},[1127,7885,7832],{"class":1158},[1127,7887,1162],{"class":1154},[1127,7889,1569],{"class":1144},[1127,7891,7792],{"class":2216},[1127,7893,1752],{"class":1144},[1127,7895,7863],{"class":2210},[1127,7897,1736],{"class":1144},[1127,7899,4085],{"class":1168},[1127,7901,7902],{"class":1144},"])\n",[1127,7904,7905],{"class":1129,"line":1358},[1127,7906,3202],{"class":1654},[1127,7908,7909,7911,7914,7916,7918],{"class":1129,"line":1364},[1127,7910,3450],{"class":1251},[1127,7912,7913],{"class":3086}," test_error_logging",[1127,7915,2220],{"class":1144},[1127,7917,3460],{"class":3459},[1127,7919,3096],{"class":1144},[1127,7921,7922,7924,7927],{"class":1129,"line":1378},[1127,7923,3541],{"class":3540},[1127,7925,7926],{"class":3544},"Test error logging",[1127,7928,3548],{"class":3540},[1127,7930,7931,7933,7935,7937,7939,7941,7943,7945,7947,7949,7951,7953,7955,7957,7959,7961,7963,7965],{"class":1129,"line":1392},[1127,7932,7289],{"class":1650},[1127,7934,4703],{"class":1140},[1127,7936,1752],{"class":1144},[1127,7938,7765],{"class":2216},[1127,7940,2220],{"class":1144},[1127,7942,1162],{"class":1154},[1127,7944,2849],{"class":1158},[1127,7946,1162],{"class":1154},[1127,7948,1569],{"class":1144},[1127,7950,3517],{"class":3383},[1127,7952,3057],{"class":1144},[1127,7954,1162],{"class":1154},[1127,7956,2346],{"class":1158},[1127,7958,1162],{"class":1154},[1127,7960,5578],{"class":1144},[1127,7962,3311],{"class":1650},[1127,7964,7792],{"class":1654},[1127,7966,3210],{"class":1144},[1127,7968,7969,7971,7973,7975,7977,7979,7981,7983,7985,7987],{"class":1129,"line":1413},[1127,7970,7799],{"class":1654},[1127,7972,3057],{"class":1144},[1127,7974,3060],{"class":1654},[1127,7976,1752],{"class":1144},[1127,7978,3065],{"class":2216},[1127,7980,2220],{"class":1144},[1127,7982,1162],{"class":1154},[1127,7984,2849],{"class":1158},[1127,7986,1162],{"class":1154},[1127,7988,3074],{"class":1144},[1127,7990,7991],{"class":1129,"line":1433},[1127,7992,4798],{"class":1654},[1127,7994,7995,7998],{"class":1129,"line":1438},[1127,7996,7997],{"class":1650},"            try",[1127,7999,3210],{"class":1144},[1127,8001,8002,8005,8008,8010,8012,8015,8017],{"class":1129,"line":1452},[1127,8003,8004],{"class":1650},"                raise",[1127,8006,8007],{"class":3307}," ValueError",[1127,8009,2220],{"class":1144},[1127,8011,1162],{"class":1154},[1127,8013,8014],{"class":1158},"Test error",[1127,8016,1162],{"class":1154},[1127,8018,3074],{"class":1144},[1127,8020,8021,8024,8026],{"class":1129,"line":1472},[1127,8022,8023],{"class":1650},"            except",[1127,8025,8007],{"class":3307},[1127,8027,3210],{"class":1144},[1127,8029,8030,8033,8035,8037,8039,8041,8044,8046],{"class":1129,"line":1493},[1127,8031,8032],{"class":1654},"                logger",[1127,8034,1752],{"class":1144},[1127,8036,3325],{"class":2216},[1127,8038,2220],{"class":1144},[1127,8040,1162],{"class":1154},[1127,8042,8043],{"class":1158},"An error occurred",[1127,8045,1162],{"class":1154},[1127,8047,3074],{"class":1144},[1127,8049,8050],{"class":1129,"line":1512},[1127,8051,4798],{"class":1654},[1127,8053,8054,8056,8058,8060,8062,8064,8066,8068,8070,8072,8074,8076],{"class":1129,"line":1517},[1127,8055,3668],{"class":1140},[1127,8057,1752],{"class":1144},[1127,8059,7849],{"class":2216},[1127,8061,2220],{"class":1144},[1127,8063,5570],{"class":3453},[1127,8065,2220],{"class":1144},[1127,8067,7858],{"class":2216},[1127,8069,1752],{"class":1144},[1127,8071,7863],{"class":2210},[1127,8073,7866],{"class":1144},[1127,8075,1169],{"class":1168},[1127,8077,3074],{"class":1144},[1127,8079,8080,8082,8084,8086,8088,8090,8092,8094,8096,8098,8100,8102,8104,8106],{"class":1129,"line":1522},[1127,8081,3668],{"class":1140},[1127,8083,1752],{"class":1144},[1127,8085,7879],{"class":2216},[1127,8087,2220],{"class":1144},[1127,8089,1162],{"class":1154},[1127,8091,8043],{"class":1158},[1127,8093,1162],{"class":1154},[1127,8095,1569],{"class":1144},[1127,8097,7792],{"class":2216},[1127,8099,1752],{"class":1144},[1127,8101,7863],{"class":2210},[1127,8103,1736],{"class":1144},[1127,8105,4085],{"class":1168},[1127,8107,7902],{"class":1144},[1030,8109,921],{"id":8110},"best-practices",[8112,8113,8114,8120,8126,8132,8137,8142,8148,8154],"ol",{},[1072,8115,8116,8119],{},[1045,8117,8118],{},"Use Appropriate Log Levels",": DEBUG for development, INFO for production events, ERROR for failures",[1072,8121,8122,8125],{},[1045,8123,8124],{},"Include Context",": Add relevant information (user, request ID, etc.) to log messages",[1072,8127,8128,8131],{},[1045,8129,8130],{},"Rotate Log Files",": Use RotatingFileHandler to prevent disk space issues",[1072,8133,8134,8136],{},[1045,8135,3395],{},": Use JSON format for easier parsing and analysis",[1072,8138,8139,8141],{},[1045,8140,541],{},": Never log sensitive data (passwords, tokens, personal information)",[1072,8143,8144,8147],{},[1045,8145,8146],{},"Performance",": Be mindful of logging overhead in high-traffic applications",[1072,8149,8150,8153],{},[1045,8151,8152],{},"Centralize Logs",": Use external services for production log aggregation",[1072,8155,8156,8159],{},[1045,8157,8158],{},"Monitor Logs",": Set up alerts for critical errors and unusual patterns",[1026,8161,8162],{},"Effective logging is crucial for maintaining healthy Django applications, enabling quick debugging, performance monitoring, and security auditing across all environments.",[1277,8164,8165],{},"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 .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 .sbYkP, html code.shiki .sbYkP{--shiki-light:#39ADB5;--shiki-default:#B5695977;--shiki-dark:#C98A7D77}html pre.shiki code .sTbE_, html code.shiki .sTbE_{--shiki-light:#91B859;--shiki-default:#B56959;--shiki-dark:#C98A7D}html pre.shiki code .s7CZa, html code.shiki .s7CZa{--shiki-light:#F76D47;--shiki-default:#2F798A;--shiki-dark:#4C9A91}html pre.shiki code .s8XtY, html code.shiki .s8XtY{--shiki-light:#39ADB5;--shiki-default:#1E754F;--shiki-dark:#4D9375}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 .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 .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 .sftqT, html code.shiki .sftqT{--shiki-light:#90A4AE;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .sBPpx, html code.shiki .sBPpx{--shiki-light:#E53935;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .siWMO, html code.shiki .siWMO{--shiki-light:#6182B8;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .s6DHA, html code.shiki .s6DHA{--shiki-light:#6182B8;--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 .s131V, html code.shiki .s131V{--shiki-light:#90A4AE;--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 .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 .sa2tF, html code.shiki .sa2tF{--shiki-light:#E2931D;--shiki-default:#998418;--shiki-dark:#B8A965}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 .sD-vU, html code.shiki .sD-vU{--shiki-light:#E2931D;--shiki-default:#2E8F82;--shiki-dark:#5DA994}html pre.shiki code .sJdAF, html code.shiki .sJdAF{--shiki-light:#6182B8;--shiki-default:#998418;--shiki-dark:#B8A965}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}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 .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 .sFGJz, html code.shiki .sFGJz{--shiki-light:#E53935;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sYn-s, html code.shiki .sYn-s{--shiki-light:#E2931D;--shiki-default:#59873A;--shiki-dark:#80A665}",{"title":1123,"searchDepth":1130,"depth":1137,"links":8167},[8168,8172,8176,8181,8186,8190,8191],{"id":1032,"depth":1137,"text":1033,"children":8169},[8170,8171],{"id":1040,"depth":1151,"text":1041},{"id":1063,"depth":1151,"text":1064},{"id":1111,"depth":1137,"text":1112,"children":8173},[8174,8175],{"id":1115,"depth":1151,"text":1116},{"id":1635,"depth":1151,"text":1636},{"id":3023,"depth":1137,"text":3024,"children":8177},[8178,8179,8180],{"id":3027,"depth":1151,"text":3028},{"id":3394,"depth":1151,"text":3395},{"id":4425,"depth":1151,"text":4426},{"id":5248,"depth":1137,"text":5249,"children":8182},[8183,8184,8185],{"id":5252,"depth":1151,"text":5253},{"id":5813,"depth":1151,"text":5814},{"id":6352,"depth":1151,"text":6353},{"id":6929,"depth":1137,"text":6930,"children":8187},[8188,8189],{"id":6933,"depth":1151,"text":6934},{"id":7382,"depth":1151,"text":7383},{"id":7681,"depth":1137,"text":7682},{"id":8110,"depth":1137,"text":921},"md",null,{},{"title":851,"description":1028},"CY6fKj7kVZ8Ol0vnJwisRwaY3KtRtsweBghOFhyOg0c",[8198,8200],{"title":847,"path":848,"stem":849,"description":8199,"children":-1},"Advanced security hardening goes beyond Django's built-in security features to implement enterprise-grade security measures. This comprehensive guide covers advanced authentication, authorization patterns, security monitoring, compliance frameworks, and defense-in-depth strategies for production Django applications.",{"title":857,"path":858,"stem":859,"description":8201,"children":-1},"This comprehensive guide addresses the most common questions, issues, and problems Django developers encounter. From setup and configuration to deployment and performance, find solutions to typical Django challenges.",1772474960836]