/
models.py
61 lines (48 loc) · 1.91 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
from django.db import models
class Domain(models.Model):
domain = models.CharField(max_length=255, blank=True, unique=True)
category = models.CharField(max_length=255, blank=True)
subcategory = models.CharField(max_length=255, blank=True)
def __unicode__(self):
categories = [self.category]
if self.subcategory:
categories.append(self.subcategory)
return u": ".join((self.domain, ",".join(categories)))
class CanonicalUrl(models.Model):
url = models.TextField(unique=True)
# denormalization
domain = models.ForeignKey(Domain, null=True)
first_appearance = models.DateTimeField(null=True)
tweet_count = models.IntegerField(default=0)
def __unicode__(self):
return unicode(self.url)
class ShortUrl(models.Model):
short = models.URLField(unique=True, db_index=True)
url = models.ForeignKey(CanonicalUrl)
def __unicode__(self):
return unicode(self.url)
class HashTag(models.Model):
tag = models.CharField(max_length=140, unique=True, db_index=True)
def __unicode__(self):
return unicode(self.tag)
class Tweet(models.Model):
twitter_id = models.BigIntegerField()
text = models.CharField(max_length=255)
profile_image_url = models.URLField(blank=True)
day = models.DateField()
hour = models.IntegerField()
minute = models.IntegerField()
created_at = models.DateTimeField()
geo = models.CharField(max_length=255, null=True)
from_user = models.CharField(max_length=16)
from_user_id = models.BigIntegerField()
language = models.CharField(max_length=2)
to_user = models.CharField(max_length=16, null=True)
to_user_id = models.BigIntegerField(null=True)
source = models.CharField(max_length=255)
urls = models.ManyToManyField(CanonicalUrl)
tags = models.ManyToManyField(HashTag)
def __unicode__(self):
return self.text
class Meta:
ordering = ['id']