cdrf-expert
CDRF Expert
Instructions
- Classify the request.
Map the user request to one or more categories:
- Class selection (APIView vs GenericAPIView vs concrete generics vs ViewSets)
- Lifecycle tracing (request-to-response flow)
- Override strategy (which hook to customize)
- MRO debugging (method came from mixin/base class)
- Version differences (behavior changed between DRF versions)
- Read only the required reference file(s).
Load the minimum needed context:
references/class-selection-matrix.mdfor class selectionreferences/lifecycle-and-overrides.mdfor hook placement and lifecyclereferences/mro-debugging-playbook.mdfor MRO/source-of-method tracingreferences/version-check-workflow.mdfor DRF-version comparisons
- Navigate cdrf.co with version-first discipline.
- Identify the project DRF version from user context.
- If unknown, ask for version or provide a version-agnostic answer and explicitly mark assumptions.
- Open the matching CDRF version namespace first (for example
https://www.cdrf.co/3.16/). - Open the target class page and extract:
- Ancestors and MRO
- Available methods and source class for each method
- Default attributes that affect behavior (
queryset,serializer_class, pagination/filter backends)
- Choose the minimal override point.
- Prefer narrow hooks (
perform_create,perform_update,perform_destroy) before broad methods (create,update,destroy). - Prefer
get_querysetandget_serializer_classfor per-request behavior over hardcoding class attributes. - Keep HTTP orchestration in view methods and business/domain logic outside views.
- Preserve DRF defaults unless the request needs behavior changes.
- Produce an answer grounded in method flow.
Return:
- Recommended class
- Method(s) to override
- Why these methods are correct in the MRO/lifecycle
- Concise code patch or skeleton
- Risks/regressions and tests to add
- Validate before finalizing.
Check for common regressions:
- Accidentally bypassing permission/authentication/filter/pagination hooks
- Duplicating object-save logic between serializer and view
- Overriding broad methods when narrow hooks are sufficient
- Depending on methods not present in the selected DRF version
Error Handling
- If cdrf.co is unavailable, state that limitation and fall back to DRF official docs and installed source code.
- If the user cannot provide DRF version, provide a version-agnostic path and clearly mark assumptions.
- If multiple override points appear valid, recommend the narrowest hook first and explain tradeoffs.
Output Rules
- Cite exact class and method names from CDRF.
- State assumptions when DRF version is unknown.
- Keep responses focused on DRF CBV internals and actionable code changes.
More from vintasoftware/django-ai-plugins
django-expert
Expert Django backend development guidance. Use when creating Django models, views, serializers, or APIs; debugging ORM queries or migrations; optimizing database performance; implementing authentication; writing tests; or working with Django REST Framework. Follows Django best practices and modern patterns.
3.3Kdjango-celery-expert
Expert Django Celery guidance for asynchronous task processing. Use when designing background tasks, configuring Celery workers, handling task retries and errors, optimizing Celery performance, implementing periodic tasks with Celery Beat, or setting up production monitoring for Celery. Do not use for general Django questions unrelated to Celery, non-Celery task systems (Django Q, Huey, RQ), ML/data pipeline orchestration (Airflow, Prefect), or frontend and API-only concerns. Follows Vinta's Django Celery best practices.
546