+ return "%s Token %s for %s" % (self.get_token_type_display(), self.key, self.consumer)
+
+
+class SessionTransferToken(models.Model):
+ token = models.UUIDField(default=uuid.uuid4, primary_key=True, editable=False)
+ user = models.ForeignKey(
+ settings.AUTH_USER_MODEL, models.CASCADE)
+ created_at = models.DateTimeField(auto_now_add=True)
+ expires_at = models.DateTimeField()
+ used = models.BooleanField(default=False)
+
+ @classmethod
+ def create_for_user(cls, user, lifetime_seconds=30):
+ return cls.objects.create(
+ user=user,
+ expires_at=timezone.now() + timedelta(seconds=lifetime_seconds)
+ )
+
+ def is_valid(self):
+ if self.used:
+ return False
+ if timezone.now() > self.expires_at:
+ return False
+ return True