mirror of
https://gitlab.com/SIGBUS/nyaa.git
synced 2025-01-03 01:35:40 +00:00
Add registration IP (#507)
This will keep track of which IP a user has registered from, to prevent evading rangebans. It will only be shown to admins.
This commit is contained in:
parent
a38e5d5b53
commit
8644472533
28
migrations/versions/f703f911d4ae_add_registration_ip.py
Normal file
28
migrations/versions/f703f911d4ae_add_registration_ip.py
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
"""add registration IP
|
||||||
|
|
||||||
|
Revision ID: f703f911d4ae
|
||||||
|
Revises: f69d7fec88d6
|
||||||
|
Create Date: 2018-07-09 13:04:50.652781
|
||||||
|
|
||||||
|
"""
|
||||||
|
from alembic import op
|
||||||
|
import sqlalchemy as sa
|
||||||
|
|
||||||
|
|
||||||
|
# revision identifiers, used by Alembic.
|
||||||
|
revision = 'f703f911d4ae'
|
||||||
|
down_revision = 'f69d7fec88d6'
|
||||||
|
branch_labels = None
|
||||||
|
depends_on = None
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade():
|
||||||
|
# ### commands auto generated by Alembic - please adjust! ###
|
||||||
|
op.add_column('users', sa.Column('registration_ip', sa.Binary(), nullable=True))
|
||||||
|
# ### end Alembic commands ###
|
||||||
|
|
||||||
|
|
||||||
|
def downgrade():
|
||||||
|
# ### commands auto generated by Alembic - please adjust! ###
|
||||||
|
op.drop_column('users', 'registration_ip')
|
||||||
|
# ### end Alembic commands ###
|
|
@ -487,6 +487,7 @@ class User(db.Model):
|
||||||
created_time = db.Column(db.DateTime(timezone=False), default=datetime.utcnow)
|
created_time = db.Column(db.DateTime(timezone=False), default=datetime.utcnow)
|
||||||
last_login_date = db.Column(db.DateTime(timezone=False), default=None, nullable=True)
|
last_login_date = db.Column(db.DateTime(timezone=False), default=None, nullable=True)
|
||||||
last_login_ip = db.Column(db.Binary(length=16), default=None, nullable=True)
|
last_login_ip = db.Column(db.Binary(length=16), default=None, nullable=True)
|
||||||
|
registration_ip = db.Column(db.Binary(length=16), default=None, nullable=True)
|
||||||
|
|
||||||
nyaa_torrents = db.relationship('NyaaTorrent', back_populates='user', lazy='dynamic')
|
nyaa_torrents = db.relationship('NyaaTorrent', back_populates='user', lazy='dynamic')
|
||||||
nyaa_comments = db.relationship('NyaaComment', back_populates='user', lazy='dynamic')
|
nyaa_comments = db.relationship('NyaaComment', back_populates='user', lazy='dynamic')
|
||||||
|
@ -573,6 +574,11 @@ class User(db.Model):
|
||||||
if self.last_login_ip:
|
if self.last_login_ip:
|
||||||
return str(ip_address(self.last_login_ip))
|
return str(ip_address(self.last_login_ip))
|
||||||
|
|
||||||
|
@property
|
||||||
|
def reg_ip_string(self):
|
||||||
|
if self.registration_ip:
|
||||||
|
return str(ip_address(self.registration_ip))
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def by_id(cls, id):
|
def by_id(cls, id):
|
||||||
return cls.query.get(id)
|
return cls.query.get(id)
|
||||||
|
|
|
@ -36,7 +36,9 @@
|
||||||
<dd>{{ user.userstatus_str }}</dt>
|
<dd>{{ user.userstatus_str }}</dt>
|
||||||
{%- if g.user.is_superadmin -%}
|
{%- if g.user.is_superadmin -%}
|
||||||
<dt>Last login IP:</dt>
|
<dt>Last login IP:</dt>
|
||||||
<dd>{{ user.ip_string }}</dd><br>
|
<dd>{{ user.ip_string }}</dd>
|
||||||
|
<dt>Registration IP:</dt>
|
||||||
|
<dd>{{ user.reg_ip_string }}</dd>
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
</dl>
|
</dl>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -86,10 +86,11 @@ def register():
|
||||||
if flask.request.method == 'POST' and form.validate():
|
if flask.request.method == 'POST' and form.validate():
|
||||||
user = models.User(username=form.username.data.strip(),
|
user = models.User(username=form.username.data.strip(),
|
||||||
email=form.email.data.strip(), password=form.password.data)
|
email=form.email.data.strip(), password=form.password.data)
|
||||||
user.last_login_ip = ip_address(flask.request.remote_addr).packed
|
user.registration_ip = ip_address(flask.request.remote_addr).packed
|
||||||
|
user.last_login_ip = user.registration_ip
|
||||||
db.session.add(user)
|
db.session.add(user)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
if models.RangeBan.is_rangebanned(user.last_login_ip):
|
if models.RangeBan.is_rangebanned(user.registration_ip):
|
||||||
flask.flash(flask.Markup('Your IP is blocked from creating new accounts. '
|
flask.flash(flask.Markup('Your IP is blocked from creating new accounts. '
|
||||||
'Please <a href="{}">ask a moderator</a> to manually '
|
'Please <a href="{}">ask a moderator</a> to manually '
|
||||||
'activate your account <a href="{}">\'{}\'</a>.'
|
'activate your account <a href="{}">\'{}\'</a>.'
|
||||||
|
|
Loading…
Reference in a new issue