|
@@ -25,6 +25,7 @@ class User(Model):
|
|
|
|
|
|
name = peewee.TextField(unique=True)
|
|
name = peewee.TextField(unique=True)
|
|
passhash = peewee.TextField()
|
|
passhash = peewee.TextField()
|
|
|
|
+ is_admin = peewee.BooleanField(default=False)
|
|
|
|
|
|
@staticmethod
|
|
@staticmethod
|
|
def from_request(user: r.User) -> "User":
|
|
def from_request(user: r.User) -> "User":
|
|
@@ -37,6 +38,10 @@ class User(Model):
|
|
def authenticate(self, password: str) -> bool:
|
|
def authenticate(self, password: str) -> bool:
|
|
return pwd.verify(password, self.passhash)
|
|
return pwd.verify(password, self.passhash)
|
|
|
|
|
|
|
|
+ def set_as_admin(self):
|
|
|
|
+ self.is_admin = True
|
|
|
|
+ self.save()
|
|
|
|
+
|
|
@staticmethod
|
|
@staticmethod
|
|
def login(user: r.User) -> "User":
|
|
def login(user: r.User) -> "User":
|
|
u = User.by_slug(user.name)
|
|
u = User.by_slug(user.name)
|
|
@@ -92,7 +97,7 @@ class Link(Model):
|
|
name=link.name,
|
|
name=link.name,
|
|
description=link.description,
|
|
description=link.description,
|
|
private=link.private,
|
|
private=link.private,
|
|
- created=datetime.datetime.now(),
|
|
|
|
|
|
+ created=link.created or datetime.datetime.now(),
|
|
user=user,
|
|
user=user,
|
|
)
|
|
)
|
|
for tag_name in link.tags:
|
|
for tag_name in link.tags:
|