First a little background:
I have an Event
model that has various event_type
s. I want to break one of those event types, 'Film', into it's own admin. I have the basic functionality in place: a proxy model inheriting from Event
, named Film
, a custom manager for that proxy model that filters it to only 'film' event types, and it's own ModelAdmin.
The problem is with the reverse. I now need to filter out films from the main Event
admin. I don't want to alter the Event
model or its default manager, because the impact would be too widespread. So, I tried creating another proxy model, EventAdminProxy
, with the sole purpose of providing a filtered list of events in the admin. I then register this model, instead of Event
, with the existing ModelAdmin.
This obviously works, but it has the unfortunate side-effect of altering the URLs in the admin. Instead of the changelist being at "/admin/event/event/", it's now at "/admin/event/eventadminproxy/".
What I'm trying to do is keep this setup, but also keep the old URL. I've tried overloading the ModelAdmin's get_urls
method, but from what I can tell, you can't control the full URL there, only what comes after the "/app_label/model_class/" part.
I thought about overriding it in the main urls.py, but can't figure out an acceptable view to tie into. The actual views are only available on the instantiated ModelAdmin object, not the class itself.
Any ideas of how override the URL being used in the admin?
Looking at the Django source, the admin URLs are built in two places, in the
ModelAdmin
instances, and in theAdminSite
instances.The part you want to change is built in the AdminSite instance (
django.contrib.admin.sites.AdminSite
), you can subclass that and override theget_urls
method. If you look at the second half of the method you'll see this:There it is adding the model's ._meta.module_name which is just the model's name lowercased (
django.db.models.options.Options.contribute_to_class
).An easy way out is to override the Site's
get_urls
method and add a dict or special case for the Proxy model so it uses a different url instead ofmodel._meta.module_name
, something along the lines:You could override the queryset-method of your
EventModelAdmin
and filter the queryset so that Film-Events get excluded.Something similar to this: