I just got done working through the Django tutorials for the second time, and am understanding things much more clearly now. However, I’m still unclear how apps inside a site interact with one another.
For example, lets say I’m writing a blog application (a rather popular activity, apparently). Blog posts and comments tend to go together, and yet they are distinct enough that they should be built into separate apps, as is the general philosophy of Djano development.
Consider the following example. In reality I would not actually write the comment app myself, as good code for that already exists on the web, but this is for demonstration/practice purposes:
mysite/blog/models.py
from django.db import models class post(models.Model): title = models.CharField(max_length=200) author = models.CharField(max_length=200) content = models.TextField()
mysite/comments/models.py
from django.db import models from mysite.blog.models import post class comment(models.Model): id = models.AutoField() post = models.ForeignKey(post) author = models.CharField(max_length=200) text = models.TextField()
Is what I wrote above, importing a model from another app and setting it as a foreign key, how Django apps interact? Or is there a different/better method for the apps that comprise a site to interact?
Update
Per the recommendation in one response, I’m reading the documentation for contrib.contenttypes. If I’m reading this correctly, I could rewrite my example comment app like this:
from django.db import models from django.contrib.contenttypes.models import ContentType from django.contrib.contentypes import generic class comment(models.Model): id = models.AutoField() author = models.CharField(max_length=200) text = models.TextField() content_type = models.ForeignKey(ContentType) content_object = generic.GenericForeignKey(content_type, id)
Would this be correct?
Take a look at django’s built-in contenttypes framework:
django.contrib.contenttypesIt allows you develop your applications as stand-alone units. This is what the django developers used to allow django’s built-in comment framework to attach a comment to any model in your project.
For instance, if you have some content object that you want to ‘attach’ to other content objects of different types, like allowing each user to leave a ‘favorite’ star on a blog post, image, or user profile, you can create a
Favoritemodel with a generic relation field like so:In this way you can add a
Favoritestar from any user to any model in your project. If you want to add API access via the recipient model class you can either add a reverse generic relation field on the recipient model (although this would be ‘coupling’ the two models, which you said you wanted to avoid), or do the lookup through theFavoritemodel with thecontent_typeandobject_idof the recipient instance, see the official docs for an example.