class User(UserMixin, db.Document): username = db.StringField(max_length=255, required=True) email = db.EmailField(max_length=255) password_hash = db.StringField(required=True) create_time = db.DateTimeField(default=datetime.datetime.now, required=True) last_login = db.DateTimeField(default=datetime.datetime.now, required=True) is_email_confirmed = db.BooleanField(default=False) # is_active = db.BooleanField(default=True) is_superuser = db.BooleanField(default=False) role = db.StringField(max_length=32, default='reader', choices=ROLES) display_name = db.StringField(max_length=255, default='Anonymous') biography = db.StringField() social_networks = db.DictField(default=SOCIAL_NETWORKS) homepage_url = db.URLField() @property def password(self): raise AttributeError('password is not a readle attribute') @password.setter def password(self, password): self.password_hash = generate_password_hash(password) def verify_password(self, password): return check_password_hash(self.password_hash, password) def get_id(self): try: return unicode(self.username) except AttributeError: raise NotImplementedError('No `username` attribute - override `get_id`') def __unicode__(self): return self.username
class Draft(db.Document): title = db.StringField(max_length=255, default='new blog', required=True) slug = db.StringField(max_length=255, required=True, unique=True) # fix_slug = db.StringField(max_length=255, required=False) abstract = db.StringField() raw = db.StringField(required=True) pub_time = db.DateTimeField() update_time = db.DateTimeField() content_html = db.StringField(required=True) author = db.ReferenceField(User) category = db.StringField(max_length=64, default='default') tags = db.ListField(db.StringField(max_length=30)) is_draft = db.BooleanField(default=True) post_type = db.StringField(max_length=64, default='post') weight = db.IntField(default=10) def save(self, *args, **kwargs): now = datetime.datetime.utcnow() if not self.pub_time: self.pub_time = now self.update_time = now self.content_html = markdown2.markdown( self.raw, extras=['code-friendly', 'fenced-code-blocks', 'tables']) self.content_html = get_clean_html_content(self.content_html) return super(Draft, self).save(*args, **kwargs) def __unicode__(self): return self.title meta = { 'allow_inheritance': True, 'indexes': ['slug'], 'ordering': ['-update_time'] }
class Post(db.Document): title = db.StringField(max_length=255, default='new blog', required=True) slug = db.StringField(max_length=255, required=True, unique=True) fix_slug = db.StringField(max_length=255, required=False) abstract = db.StringField() raw = db.StringField(required=True) pub_time = db.DateTimeField() update_time = db.DateTimeField() content_html = db.StringField(required=True) author = db.ReferenceField(User) category = db.StringField(max_length=64) tags = db.ListField(db.StringField(max_length=30)) is_draft = db.BooleanField(default=False) post_type = db.StringField(max_length=64, default='post') def get_absolute_url(self): # return url_for('main.post_detail', slug=self.slug) router = { 'post': url_for('main.post_detail', slug=self.slug, _external=True), 'page': url_for('main.page_detail', slug=self.slug, _external=True), 'wechat': url_for('main.wechat_detail', slug=self.slug, _external=True), } return router[self.post_type] def save(self, allow_set_time=False, *args, **kwargs): if not allow_set_time: now = datetime.datetime.now() if not self.pub_time: self.pub_time = now self.update_time = now # self.content_html = self.raw self.content_html = markdown2.markdown( self.raw, extras=['code-friendly', 'fenced-code-blocks', 'tables']).encode('utf-8') return super(Post, self).save(*args, **kwargs) def set_post_date(self, pub_time, update_time): self.pub_time = pub_time self.update_time = update_time return self.save(allow_set_time=True) def __unicode__(self): return self.title meta = { 'allow_inheritance': True, 'indexes': ['slug'], 'ordering': ['-pub_time'] }
class User(UserMixin, db.Document): username = db.StringField(max_length=255, required=True) email = db.EmailField(max_length=255) password_hash = db.StringField(required=True) create_time = db.DateTimeField(default=datetime.datetime.now, required=True) last_login = db.DateTimeField(default=datetime.datetime.now, required=True) is_email_confirmed = db.BooleanField(default=False) # is_active = db.BooleanField(default=True) is_superuser = db.BooleanField(default=False) role = db.StringField(max_length=32, default='reader', choices=ROLES) display_name = db.StringField(max_length=255, default=username) biography = db.StringField() social_networks = db.DictField(default=SOCIAL_NETWORKS) homepage_url = db.URLField() confirm_email_sent_time = db.DateTimeField() @property def password(self): raise AttributeError('password is not a readle attribute') @password.setter def password(self, password): self.password_hash = generate_password_hash(password) def verify_password(self, password): return check_password_hash(self.password_hash, password) def generate_confirmation_token(self, expiration=3600): serializer = TimedJSONWebSignatureSerializer( current_app.config['SECRET_KEY'], expiration) return serializer.dumps({'confirm': self.username}) def confirm_email(self, token, expiration=3600): s = TimedJSONWebSignatureSerializer(current_app.config['SECRET_KEY']) try: data = s.loads(token) except Exception: return False if data.get('confirm') != self.username: return False self.is_email_confirmed = True self.save() return True def generate_reset_token(self, expiration=3600): serializer = TimedJSONWebSignatureSerializer( current_app.config['SECRET_KEY'], expiration) return serializer.dumps({'reset': self.username}) @staticmethod def reset_password(token, new_password): serializer = TimedJSONWebSignatureSerializer( current_app.config['SECRET_KEY']) try: data = serializer.loads(token) except: return False try: user = User.objects.get(username=data.get('reset')) except Exception: return False user.password = new_password user.save() return True def get_id(self): try: # return unicode(self.username) return self.username except AttributeError: raise NotImplementedError( 'No `username` attribute - override `get_id`') def __unicode__(self): return self.username